libctf: create: ctf_add_type should hand back already-added non-SoUs
[deliverable/binutils-gdb.git] / libctf / ctf-open.c
CommitLineData
72f33921 1/* Opening CTF files.
b3adc24a 2 Copyright (C) 2019-2020 Free Software Foundation, Inc.
72f33921
NA
3
4 This file is part of libctf.
5
6 libctf is free software; you can redistribute it and/or modify it under
7 the terms of the GNU General Public License as published by the Free
8 Software Foundation; either version 3, or (at your option) any later
9 version.
10
11 This program is distributed in the hope that it will be useful, but
12 WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
14 See the GNU General Public License for more details.
15
16 You should have received a copy of the GNU General Public License
17 along with this program; see the file COPYING. If not see
18 <http://www.gnu.org/licenses/>. */
19
20#include <ctf-impl.h>
21#include <stddef.h>
22#include <string.h>
23#include <sys/types.h>
24#include <elf.h>
25#include <assert.h>
26#include "swap.h"
27#include <bfd.h>
28#include <zlib.h>
29
30#include "elf-bfd.h"
31
32static const ctf_dmodel_t _libctf_models[] = {
33 {"ILP32", CTF_MODEL_ILP32, 4, 1, 2, 4, 4},
34 {"LP64", CTF_MODEL_LP64, 8, 1, 2, 4, 8},
35 {NULL, 0, 0, 0, 0, 0, 0}
36};
37
38const char _CTF_SECTION[] = ".ctf";
39const char _CTF_NULLSTR[] = "";
40
41/* Version-sensitive accessors. */
42
43static uint32_t
44get_kind_v1 (uint32_t info)
45{
46 return (CTF_V1_INFO_KIND (info));
47}
48
49static uint32_t
50get_root_v1 (uint32_t info)
51{
52 return (CTF_V1_INFO_ISROOT (info));
53}
54
55static uint32_t
56get_vlen_v1 (uint32_t info)
57{
58 return (CTF_V1_INFO_VLEN (info));
59}
60
61static uint32_t
62get_kind_v2 (uint32_t info)
63{
64 return (CTF_V2_INFO_KIND (info));
65}
66
67static uint32_t
68get_root_v2 (uint32_t info)
69{
70 return (CTF_V2_INFO_ISROOT (info));
71}
72
73static uint32_t
74get_vlen_v2 (uint32_t info)
75{
76 return (CTF_V2_INFO_VLEN (info));
77}
78
79static inline ssize_t
80get_ctt_size_common (const ctf_file_t *fp _libctf_unused_,
81 const ctf_type_t *tp _libctf_unused_,
82 ssize_t *sizep, ssize_t *incrementp, size_t lsize,
83 size_t csize, size_t ctf_type_size,
84 size_t ctf_stype_size, size_t ctf_lsize_sent)
85{
86 ssize_t size, increment;
87
88 if (csize == ctf_lsize_sent)
89 {
90 size = lsize;
91 increment = ctf_type_size;
92 }
93 else
94 {
95 size = csize;
96 increment = ctf_stype_size;
97 }
98
99 if (sizep)
100 *sizep = size;
101 if (incrementp)
102 *incrementp = increment;
103
104 return size;
105}
106
107static ssize_t
108get_ctt_size_v1 (const ctf_file_t *fp, const ctf_type_t *tp,
109 ssize_t *sizep, ssize_t *incrementp)
110{
111 ctf_type_v1_t *t1p = (ctf_type_v1_t *) tp;
112
113 return (get_ctt_size_common (fp, tp, sizep, incrementp,
114 CTF_TYPE_LSIZE (t1p), t1p->ctt_size,
115 sizeof (ctf_type_v1_t), sizeof (ctf_stype_v1_t),
116 CTF_LSIZE_SENT_V1));
117}
118
119/* Return the size that a v1 will be once it is converted to v2. */
120
121static ssize_t
122get_ctt_size_v2_unconverted (const ctf_file_t *fp, const ctf_type_t *tp,
123 ssize_t *sizep, ssize_t *incrementp)
124{
125 ctf_type_v1_t *t1p = (ctf_type_v1_t *) tp;
126
127 return (get_ctt_size_common (fp, tp, sizep, incrementp,
128 CTF_TYPE_LSIZE (t1p), t1p->ctt_size,
129 sizeof (ctf_type_t), sizeof (ctf_stype_t),
130 CTF_LSIZE_SENT));
131}
132
133static ssize_t
134get_ctt_size_v2 (const ctf_file_t *fp, const ctf_type_t *tp,
135 ssize_t *sizep, ssize_t *incrementp)
136{
137 return (get_ctt_size_common (fp, tp, sizep, incrementp,
138 CTF_TYPE_LSIZE (tp), tp->ctt_size,
139 sizeof (ctf_type_t), sizeof (ctf_stype_t),
140 CTF_LSIZE_SENT));
141}
142
143static ssize_t
144get_vbytes_common (unsigned short kind, ssize_t size _libctf_unused_,
145 size_t vlen)
146{
147 switch (kind)
148 {
149 case CTF_K_INTEGER:
150 case CTF_K_FLOAT:
151 return (sizeof (uint32_t));
152 case CTF_K_SLICE:
7cee1826 153 return (sizeof (ctf_slice_t));
72f33921
NA
154 case CTF_K_ENUM:
155 return (sizeof (ctf_enum_t) * vlen);
156 case CTF_K_FORWARD:
157 case CTF_K_UNKNOWN:
158 case CTF_K_POINTER:
159 case CTF_K_TYPEDEF:
160 case CTF_K_VOLATILE:
161 case CTF_K_CONST:
162 case CTF_K_RESTRICT:
163 return 0;
164 default:
165 ctf_dprintf ("detected invalid CTF kind -- %x\n", kind);
166 return ECTF_CORRUPT;
167 }
168}
169
170static ssize_t
171get_vbytes_v1 (unsigned short kind, ssize_t size, size_t vlen)
172{
173 switch (kind)
174 {
175 case CTF_K_ARRAY:
176 return (sizeof (ctf_array_v1_t));
177 case CTF_K_FUNCTION:
178 return (sizeof (unsigned short) * (vlen + (vlen & 1)));
179 case CTF_K_STRUCT:
180 case CTF_K_UNION:
181 if (size < CTF_LSTRUCT_THRESH_V1)
182 return (sizeof (ctf_member_v1_t) * vlen);
183 else
184 return (sizeof (ctf_lmember_v1_t) * vlen);
185 }
186
187 return (get_vbytes_common (kind, size, vlen));
188}
189
190static ssize_t
191get_vbytes_v2 (unsigned short kind, ssize_t size, size_t vlen)
192{
193 switch (kind)
194 {
195 case CTF_K_ARRAY:
196 return (sizeof (ctf_array_t));
197 case CTF_K_FUNCTION:
198 return (sizeof (uint32_t) * (vlen + (vlen & 1)));
199 case CTF_K_STRUCT:
200 case CTF_K_UNION:
201 if (size < CTF_LSTRUCT_THRESH)
202 return (sizeof (ctf_member_t) * vlen);
203 else
204 return (sizeof (ctf_lmember_t) * vlen);
205 }
206
207 return (get_vbytes_common (kind, size, vlen));
208}
209
210static const ctf_fileops_t ctf_fileops[] = {
211 {NULL, NULL, NULL, NULL, NULL},
212 /* CTF_VERSION_1 */
213 {get_kind_v1, get_root_v1, get_vlen_v1, get_ctt_size_v1, get_vbytes_v1},
214 /* CTF_VERSION_1_UPGRADED_3 */
215 {get_kind_v2, get_root_v2, get_vlen_v2, get_ctt_size_v2, get_vbytes_v2},
216 /* CTF_VERSION_2 */
217 {get_kind_v2, get_root_v2, get_vlen_v2, get_ctt_size_v2, get_vbytes_v2},
218 /* CTF_VERSION_3, identical to 2: only new type kinds */
219 {get_kind_v2, get_root_v2, get_vlen_v2, get_ctt_size_v2, get_vbytes_v2},
220};
221
222/* Initialize the symtab translation table by filling each entry with the
223 offset of the CTF type or function data corresponding to each STT_FUNC or
224 STT_OBJECT entry in the symbol table. */
225
226static int
227init_symtab (ctf_file_t *fp, const ctf_header_t *hp,
228 const ctf_sect_t *sp, const ctf_sect_t *strp)
229{
230 const unsigned char *symp = sp->cts_data;
231 uint32_t *xp = fp->ctf_sxlate;
232 uint32_t *xend = xp + fp->ctf_nsyms;
233
234 uint32_t objtoff = hp->cth_objtoff;
235 uint32_t funcoff = hp->cth_funcoff;
236
237 uint32_t info, vlen;
238 Elf64_Sym sym, *gsp;
239 const char *name;
240
241 /* The CTF data object and function type sections are ordered to match
242 the relative order of the respective symbol types in the symtab.
243 If no type information is available for a symbol table entry, a
244 pad is inserted in the CTF section. As a further optimization,
245 anonymous or undefined symbols are omitted from the CTF data. */
246
247 for (; xp < xend; xp++, symp += sp->cts_entsize)
248 {
249 if (sp->cts_entsize == sizeof (Elf32_Sym))
250 gsp = ctf_sym_to_elf64 ((Elf32_Sym *) (uintptr_t) symp, &sym);
251 else
252 gsp = (Elf64_Sym *) (uintptr_t) symp;
253
254 if (gsp->st_name < strp->cts_size)
255 name = (const char *) strp->cts_data + gsp->st_name;
256 else
257 name = _CTF_NULLSTR;
258
259 if (gsp->st_name == 0 || gsp->st_shndx == SHN_UNDEF
260 || strcmp (name, "_START_") == 0 || strcmp (name, "_END_") == 0)
261 {
262 *xp = -1u;
263 continue;
264 }
265
266 switch (ELF64_ST_TYPE (gsp->st_info))
267 {
268 case STT_OBJECT:
269 if (objtoff >= hp->cth_funcoff
270 || (gsp->st_shndx == SHN_EXTABS && gsp->st_value == 0))
271 {
272 *xp = -1u;
273 break;
274 }
275
276 *xp = objtoff;
277 objtoff += sizeof (uint32_t);
278 break;
279
280 case STT_FUNC:
2db912ba 281 if (funcoff >= hp->cth_objtidxoff)
72f33921
NA
282 {
283 *xp = -1u;
284 break;
285 }
286
287 *xp = funcoff;
288
289 info = *(uint32_t *) ((uintptr_t) fp->ctf_buf + funcoff);
290 vlen = LCTF_INFO_VLEN (fp, info);
291
292 /* If we encounter a zero pad at the end, just skip it. Otherwise
293 skip over the function and its return type (+2) and the argument
294 list (vlen).
295 */
296 if (LCTF_INFO_KIND (fp, info) == CTF_K_UNKNOWN && vlen == 0)
297 funcoff += sizeof (uint32_t); /* Skip pad. */
298 else
299 funcoff += sizeof (uint32_t) * (vlen + 2);
300 break;
301
302 default:
303 *xp = -1u;
304 break;
305 }
306 }
307
308 ctf_dprintf ("loaded %lu symtab entries\n", fp->ctf_nsyms);
309 return 0;
310}
311
fd55eae8
NA
312/* Reset the CTF base pointer and derive the buf pointer from it, initializing
313 everything in the ctf_file that depends on the base or buf pointers.
314
315 The original gap between the buf and base pointers, if any -- the original,
316 unconverted CTF header -- is kept, but its contents are not specified and are
317 never used. */
72f33921
NA
318
319static void
fd55eae8 320ctf_set_base (ctf_file_t *fp, const ctf_header_t *hp, unsigned char *base)
72f33921 321{
fd55eae8 322 fp->ctf_buf = base + (fp->ctf_buf - fp->ctf_base);
72f33921 323 fp->ctf_base = base;
72f33921
NA
324 fp->ctf_vars = (ctf_varent_t *) ((const char *) fp->ctf_buf +
325 hp->cth_varoff);
326 fp->ctf_nvars = (hp->cth_typeoff - hp->cth_varoff) / sizeof (ctf_varent_t);
327
328 fp->ctf_str[CTF_STRTAB_0].cts_strs = (const char *) fp->ctf_buf
329 + hp->cth_stroff;
330 fp->ctf_str[CTF_STRTAB_0].cts_len = hp->cth_strlen;
331
332 /* If we have a parent container name and label, store the relocated
333 string pointers in the CTF container for easy access later. */
334
335 /* Note: before conversion, these will be set to values that will be
336 immediately invalidated by the conversion process, but the conversion
337 process will call ctf_set_base() again to fix things up. */
338
339 if (hp->cth_parlabel != 0)
340 fp->ctf_parlabel = ctf_strptr (fp, hp->cth_parlabel);
341 if (hp->cth_parname != 0)
342 fp->ctf_parname = ctf_strptr (fp, hp->cth_parname);
fd55eae8
NA
343 if (hp->cth_cuname != 0)
344 fp->ctf_cuname = ctf_strptr (fp, hp->cth_cuname);
345
346 if (fp->ctf_cuname)
347 ctf_dprintf ("ctf_set_base: CU name %s\n", fp->ctf_cuname);
348 if (fp->ctf_parname)
349 ctf_dprintf ("ctf_set_base: parent name %s (label %s)\n",
350 fp->ctf_parname,
72f33921
NA
351 fp->ctf_parlabel ? fp->ctf_parlabel : "<NULL>");
352}
353
72f33921
NA
354/* Set the version of the CTF file. */
355
356/* When this is reset, LCTF_* changes behaviour, but there is no guarantee that
357 the variable data list associated with each type has been upgraded: the
358 caller must ensure this has been done in advance. */
359
360static void
fd55eae8 361ctf_set_version (ctf_file_t *fp, ctf_header_t *cth, int ctf_version)
72f33921
NA
362{
363 fp->ctf_version = ctf_version;
364 cth->cth_version = ctf_version;
365 fp->ctf_fileops = &ctf_fileops[ctf_version];
366}
367
fd55eae8
NA
368
369/* Upgrade the header to CTF_VERSION_3. The upgrade is done in-place. */
370static void
371upgrade_header (ctf_header_t *hp)
372{
373 ctf_header_v2_t *oldhp = (ctf_header_v2_t *) hp;
374
375 hp->cth_strlen = oldhp->cth_strlen;
376 hp->cth_stroff = oldhp->cth_stroff;
377 hp->cth_typeoff = oldhp->cth_typeoff;
378 hp->cth_varoff = oldhp->cth_varoff;
2db912ba
NA
379 hp->cth_funcidxoff = hp->cth_varoff; /* No index sections. */
380 hp->cth_objtidxoff = hp->cth_funcidxoff;
fd55eae8
NA
381 hp->cth_funcoff = oldhp->cth_funcoff;
382 hp->cth_objtoff = oldhp->cth_objtoff;
383 hp->cth_lbloff = oldhp->cth_lbloff;
384 hp->cth_cuname = 0; /* No CU name. */
385}
386
387/* Upgrade the type table to CTF_VERSION_3 (really CTF_VERSION_1_UPGRADED_3)
388 from CTF_VERSION_1.
72f33921
NA
389
390 The upgrade is not done in-place: the ctf_base is moved. ctf_strptr() must
391 not be called before reallocation is complete.
392
2db912ba
NA
393 Sections not checked here due to nonexistence or nonpopulated state in older
394 formats: objtidx, funcidx.
395
72f33921
NA
396 Type kinds not checked here due to nonexistence in older formats:
397 CTF_K_SLICE. */
398static int
fd55eae8 399upgrade_types_v1 (ctf_file_t *fp, ctf_header_t *cth)
72f33921
NA
400{
401 const ctf_type_v1_t *tbuf;
402 const ctf_type_v1_t *tend;
fd55eae8 403 unsigned char *ctf_base, *old_ctf_base = (unsigned char *) fp->ctf_dynbase;
72f33921
NA
404 ctf_type_t *t2buf;
405
406 ssize_t increase = 0, size, increment, v2increment, vbytes, v2bytes;
407 const ctf_type_v1_t *tp;
408 ctf_type_t *t2p;
72f33921
NA
409
410 tbuf = (ctf_type_v1_t *) (fp->ctf_buf + cth->cth_typeoff);
411 tend = (ctf_type_v1_t *) (fp->ctf_buf + cth->cth_stroff);
412
413 /* Much like init_types(), this is a two-pass process.
414
415 First, figure out the new type-section size needed. (It is possible,
416 in theory, for it to be less than the old size, but this is very
417 unlikely. It cannot be so small that cth_typeoff ends up of negative
418 size. We validate this with an assertion below.)
419
420 We must cater not only for changes in vlen and types sizes but also
421 for changes in 'increment', which happen because v2 places some types
422 into ctf_stype_t where v1 would be forced to use the larger non-stype. */
423
424 for (tp = tbuf; tp < tend;
425 tp = (ctf_type_v1_t *) ((uintptr_t) tp + increment + vbytes))
426 {
427 unsigned short kind = CTF_V1_INFO_KIND (tp->ctt_info);
428 unsigned long vlen = CTF_V1_INFO_VLEN (tp->ctt_info);
429
430 size = get_ctt_size_v1 (fp, (const ctf_type_t *) tp, NULL, &increment);
431 vbytes = get_vbytes_v1 (kind, size, vlen);
432
433 get_ctt_size_v2_unconverted (fp, (const ctf_type_t *) tp, NULL,
434 &v2increment);
435 v2bytes = get_vbytes_v2 (kind, size, vlen);
436
437 if ((vbytes < 0) || (size < 0))
438 return ECTF_CORRUPT;
439
440 increase += v2increment - increment; /* May be negative. */
441 increase += v2bytes - vbytes;
442 }
443
fd55eae8
NA
444 /* Allocate enough room for the new buffer, then copy everything but the type
445 section into place, and reset the base accordingly. Leave the version
446 number unchanged, so that LCTF_INFO_* still works on the
72f33921
NA
447 as-yet-untranslated type info. */
448
de07e349 449 if ((ctf_base = malloc (fp->ctf_size + increase)) == NULL)
72f33921
NA
450 return ECTF_ZALLOC;
451
fd55eae8
NA
452 /* Start at ctf_buf, not ctf_base, to squeeze out the original header: we
453 never use it and it is unconverted. */
72f33921 454
fd55eae8
NA
455 memcpy (ctf_base, fp->ctf_buf, cth->cth_typeoff);
456 memcpy (ctf_base + cth->cth_stroff + increase,
457 fp->ctf_buf + cth->cth_stroff, cth->cth_strlen);
72f33921 458
fd55eae8
NA
459 memset (ctf_base + cth->cth_typeoff, 0, cth->cth_stroff - cth->cth_typeoff
460 + increase);
72f33921 461
fd55eae8 462 cth->cth_stroff += increase;
72f33921 463 fp->ctf_size += increase;
fd55eae8
NA
464 assert (cth->cth_stroff >= cth->cth_typeoff);
465 fp->ctf_base = ctf_base;
466 fp->ctf_buf = ctf_base;
467 fp->ctf_dynbase = ctf_base;
468 ctf_set_base (fp, cth, ctf_base);
72f33921 469
fd55eae8 470 t2buf = (ctf_type_t *) (fp->ctf_buf + cth->cth_typeoff);
72f33921
NA
471
472 /* Iterate through all the types again, upgrading them.
473
474 Everything that hasn't changed can just be outright memcpy()ed.
475 Things that have changed need field-by-field consideration. */
476
477 for (tp = tbuf, t2p = t2buf; tp < tend;
478 tp = (ctf_type_v1_t *) ((uintptr_t) tp + increment + vbytes),
479 t2p = (ctf_type_t *) ((uintptr_t) t2p + v2increment + v2bytes))
480 {
481 unsigned short kind = CTF_V1_INFO_KIND (tp->ctt_info);
482 int isroot = CTF_V1_INFO_ISROOT (tp->ctt_info);
483 unsigned long vlen = CTF_V1_INFO_VLEN (tp->ctt_info);
484 ssize_t v2size;
485 void *vdata, *v2data;
486
487 size = get_ctt_size_v1 (fp, (const ctf_type_t *) tp, NULL, &increment);
488 vbytes = get_vbytes_v1 (kind, size, vlen);
489
490 t2p->ctt_name = tp->ctt_name;
491 t2p->ctt_info = CTF_TYPE_INFO (kind, isroot, vlen);
492
493 switch (kind)
494 {
495 case CTF_K_FUNCTION:
496 case CTF_K_FORWARD:
497 case CTF_K_TYPEDEF:
498 case CTF_K_POINTER:
499 case CTF_K_VOLATILE:
500 case CTF_K_CONST:
501 case CTF_K_RESTRICT:
502 t2p->ctt_type = tp->ctt_type;
503 break;
504 case CTF_K_INTEGER:
505 case CTF_K_FLOAT:
506 case CTF_K_ARRAY:
507 case CTF_K_STRUCT:
508 case CTF_K_UNION:
509 case CTF_K_ENUM:
510 case CTF_K_UNKNOWN:
a0486bac 511 if ((size_t) size <= CTF_MAX_SIZE)
72f33921
NA
512 t2p->ctt_size = size;
513 else
514 {
515 t2p->ctt_lsizehi = CTF_SIZE_TO_LSIZE_HI (size);
516 t2p->ctt_lsizelo = CTF_SIZE_TO_LSIZE_LO (size);
517 }
518 break;
519 }
520
521 v2size = get_ctt_size_v2 (fp, t2p, NULL, &v2increment);
522 v2bytes = get_vbytes_v2 (kind, v2size, vlen);
523
524 /* Catch out-of-sync get_ctt_size_*(). The count goes wrong if
525 these are not identical (and having them different makes no
526 sense semantically). */
527
528 assert (size == v2size);
529
530 /* Now the varlen info. */
531
532 vdata = (void *) ((uintptr_t) tp + increment);
533 v2data = (void *) ((uintptr_t) t2p + v2increment);
534
535 switch (kind)
536 {
537 case CTF_K_ARRAY:
538 {
539 const ctf_array_v1_t *ap = (const ctf_array_v1_t *) vdata;
540 ctf_array_t *a2p = (ctf_array_t *) v2data;
541
542 a2p->cta_contents = ap->cta_contents;
543 a2p->cta_index = ap->cta_index;
544 a2p->cta_nelems = ap->cta_nelems;
545 break;
546 }
547 case CTF_K_STRUCT:
548 case CTF_K_UNION:
549 {
550 ctf_member_t tmp;
551 const ctf_member_v1_t *m1 = (const ctf_member_v1_t *) vdata;
552 const ctf_lmember_v1_t *lm1 = (const ctf_lmember_v1_t *) m1;
553 ctf_member_t *m2 = (ctf_member_t *) v2data;
554 ctf_lmember_t *lm2 = (ctf_lmember_t *) m2;
555 unsigned long i;
556
557 /* We walk all four pointers forward, but only reference the two
558 that are valid for the given size, to avoid quadruplicating all
559 the code. */
560
561 for (i = vlen; i != 0; i--, m1++, lm1++, m2++, lm2++)
562 {
563 size_t offset;
564 if (size < CTF_LSTRUCT_THRESH_V1)
565 {
566 offset = m1->ctm_offset;
567 tmp.ctm_name = m1->ctm_name;
568 tmp.ctm_type = m1->ctm_type;
569 }
570 else
571 {
572 offset = CTF_LMEM_OFFSET (lm1);
573 tmp.ctm_name = lm1->ctlm_name;
574 tmp.ctm_type = lm1->ctlm_type;
575 }
576 if (size < CTF_LSTRUCT_THRESH)
577 {
578 m2->ctm_name = tmp.ctm_name;
579 m2->ctm_type = tmp.ctm_type;
580 m2->ctm_offset = offset;
581 }
582 else
583 {
584 lm2->ctlm_name = tmp.ctm_name;
585 lm2->ctlm_type = tmp.ctm_type;
586 lm2->ctlm_offsethi = CTF_OFFSET_TO_LMEMHI (offset);
587 lm2->ctlm_offsetlo = CTF_OFFSET_TO_LMEMLO (offset);
588 }
589 }
590 break;
591 }
592 case CTF_K_FUNCTION:
593 {
594 unsigned long i;
595 unsigned short *a1 = (unsigned short *) vdata;
596 uint32_t *a2 = (uint32_t *) v2data;
597
598 for (i = vlen; i != 0; i--, a1++, a2++)
599 *a2 = *a1;
600 }
601 /* FALLTHRU */
602 default:
603 /* Catch out-of-sync get_vbytes_*(). */
604 assert (vbytes == v2bytes);
605 memcpy (v2data, vdata, vbytes);
606 }
607 }
608
609 /* Verify that the entire region was converted. If not, we are either
610 converting too much, or too little (leading to a buffer overrun either here
611 or at read time, in init_types().) */
612
fd55eae8 613 assert ((size_t) t2p - (size_t) fp->ctf_buf == cth->cth_stroff);
72f33921 614
fd55eae8 615 ctf_set_version (fp, cth, CTF_VERSION_1_UPGRADED_3);
de07e349 616 free (old_ctf_base);
72f33921
NA
617
618 return 0;
619}
620
fd55eae8
NA
621/* Upgrade from any earlier version. */
622static int
623upgrade_types (ctf_file_t *fp, ctf_header_t *cth)
624{
625 switch (cth->cth_version)
626 {
627 /* v1 requires a full pass and reformatting. */
628 case CTF_VERSION_1:
629 upgrade_types_v1 (fp, cth);
630 /* FALLTHRU */
631 /* Already-converted v1 is just like later versions except that its
632 parent/child boundary is unchanged (and much lower). */
633
634 case CTF_VERSION_1_UPGRADED_3:
635 fp->ctf_parmax = CTF_MAX_PTYPE_V1;
636
637 /* v2 is just the same as v3 except for new types and sections:
638 no upgrading required. */
639 case CTF_VERSION_2: ;
640 /* FALLTHRU */
641 }
642 return 0;
643}
644
72f33921
NA
645/* Initialize the type ID translation table with the byte offset of each type,
646 and initialize the hash tables of each named type. Upgrade the type table to
647 the latest supported representation in the process, if needed, and if this
648 recension of libctf supports upgrading. */
649
650static int
651init_types (ctf_file_t *fp, ctf_header_t *cth)
652{
653 const ctf_type_t *tbuf;
654 const ctf_type_t *tend;
655
656 unsigned long pop[CTF_K_MAX + 1] = { 0 };
657 const ctf_type_t *tp;
72f33921
NA
658 uint32_t id, dst;
659 uint32_t *xp;
660
661 /* We determine whether the container is a child or a parent based on
662 the value of cth_parname. */
663
664 int child = cth->cth_parname != 0;
665 int nlstructs = 0, nlunions = 0;
666 int err;
667
676c3ecb
NA
668 assert (!(fp->ctf_flags & LCTF_RDWR));
669
72f33921
NA
670 if (_libctf_unlikely_ (fp->ctf_version == CTF_VERSION_1))
671 {
672 int err;
673 if ((err = upgrade_types (fp, cth)) != 0)
674 return err; /* Upgrade failed. */
675 }
676
677 tbuf = (ctf_type_t *) (fp->ctf_buf + cth->cth_typeoff);
678 tend = (ctf_type_t *) (fp->ctf_buf + cth->cth_stroff);
679
680 /* We make two passes through the entire type section. In this first
681 pass, we count the number of each type and the total number of types. */
682
683 for (tp = tbuf; tp < tend; fp->ctf_typemax++)
684 {
685 unsigned short kind = LCTF_INFO_KIND (fp, tp->ctt_info);
686 unsigned long vlen = LCTF_INFO_VLEN (fp, tp->ctt_info);
687 ssize_t size, increment, vbytes;
688
689 (void) ctf_get_ctt_size (fp, tp, &size, &increment);
690 vbytes = LCTF_VBYTES (fp, kind, size, vlen);
691
692 if (vbytes < 0)
693 return ECTF_CORRUPT;
694
695 if (kind == CTF_K_FORWARD)
696 {
697 /* For forward declarations, ctt_type is the CTF_K_* kind for the tag,
698 so bump that population count too. If ctt_type is unknown, treat
699 the tag as a struct. */
700
701 if (tp->ctt_type == CTF_K_UNKNOWN || tp->ctt_type >= CTF_K_MAX)
702 pop[CTF_K_STRUCT]++;
703 else
704 pop[tp->ctt_type]++;
705 }
706 tp = (ctf_type_t *) ((uintptr_t) tp + increment + vbytes);
707 pop[kind]++;
708 }
709
710 if (child)
711 {
712 ctf_dprintf ("CTF container %p is a child\n", (void *) fp);
713 fp->ctf_flags |= LCTF_CHILD;
714 }
715 else
716 ctf_dprintf ("CTF container %p is a parent\n", (void *) fp);
717
718 /* Now that we've counted up the number of each type, we can allocate
719 the hash tables, type translation table, and pointer table. */
720
676c3ecb
NA
721 if ((fp->ctf_structs.ctn_readonly
722 = ctf_hash_create (pop[CTF_K_STRUCT], ctf_hash_string,
723 ctf_hash_eq_string)) == NULL)
72f33921
NA
724 return ENOMEM;
725
676c3ecb
NA
726 if ((fp->ctf_unions.ctn_readonly
727 = ctf_hash_create (pop[CTF_K_UNION], ctf_hash_string,
728 ctf_hash_eq_string)) == NULL)
72f33921
NA
729 return ENOMEM;
730
676c3ecb
NA
731 if ((fp->ctf_enums.ctn_readonly
732 = ctf_hash_create (pop[CTF_K_ENUM], ctf_hash_string,
733 ctf_hash_eq_string)) == NULL)
72f33921
NA
734 return ENOMEM;
735
676c3ecb
NA
736 if ((fp->ctf_names.ctn_readonly
737 = ctf_hash_create (pop[CTF_K_INTEGER] +
738 pop[CTF_K_FLOAT] +
739 pop[CTF_K_FUNCTION] +
740 pop[CTF_K_TYPEDEF] +
741 pop[CTF_K_POINTER] +
742 pop[CTF_K_VOLATILE] +
743 pop[CTF_K_CONST] +
744 pop[CTF_K_RESTRICT],
745 ctf_hash_string,
746 ctf_hash_eq_string)) == NULL)
72f33921
NA
747 return ENOMEM;
748
de07e349 749 fp->ctf_txlate = malloc (sizeof (uint32_t) * (fp->ctf_typemax + 1));
676c3ecb 750 fp->ctf_ptrtab_len = fp->ctf_typemax + 1;
de07e349 751 fp->ctf_ptrtab = malloc (sizeof (uint32_t) * fp->ctf_ptrtab_len);
72f33921
NA
752
753 if (fp->ctf_txlate == NULL || fp->ctf_ptrtab == NULL)
754 return ENOMEM; /* Memory allocation failed. */
755
756 xp = fp->ctf_txlate;
757 *xp++ = 0; /* Type id 0 is used as a sentinel value. */
758
759 memset (fp->ctf_txlate, 0, sizeof (uint32_t) * (fp->ctf_typemax + 1));
760 memset (fp->ctf_ptrtab, 0, sizeof (uint32_t) * (fp->ctf_typemax + 1));
761
762 /* In the second pass through the types, we fill in each entry of the
763 type and pointer tables and add names to the appropriate hashes. */
764
765 for (id = 1, tp = tbuf; tp < tend; xp++, id++)
766 {
767 unsigned short kind = LCTF_INFO_KIND (fp, tp->ctt_info);
fe4c2d55 768 unsigned short isroot = LCTF_INFO_ISROOT (fp, tp->ctt_info);
72f33921
NA
769 unsigned long vlen = LCTF_INFO_VLEN (fp, tp->ctt_info);
770 ssize_t size, increment, vbytes;
771
772 const char *name;
773
774 (void) ctf_get_ctt_size (fp, tp, &size, &increment);
775 name = ctf_strptr (fp, tp->ctt_name);
776 vbytes = LCTF_VBYTES (fp, kind, size, vlen);
777
778 switch (kind)
779 {
780 case CTF_K_INTEGER:
781 case CTF_K_FLOAT:
782 /* Names are reused by bit-fields, which are differentiated by their
783 encodings, and so typically we'd record only the first instance of
784 a given intrinsic. However, we replace an existing type with a
785 root-visible version so that we can be sure to find it when
786 checking for conflicting definitions in ctf_add_type(). */
787
676c3ecb
NA
788 if (((ctf_hash_lookup_type (fp->ctf_names.ctn_readonly,
789 fp, name)) == 0)
fe4c2d55 790 || isroot)
72f33921 791 {
676c3ecb 792 err = ctf_hash_define_type (fp->ctf_names.ctn_readonly, fp,
72f33921
NA
793 LCTF_INDEX_TO_TYPE (fp, id, child),
794 tp->ctt_name);
d851ecd3 795 if (err != 0)
72f33921
NA
796 return err;
797 }
798 break;
799
800 /* These kinds have no name, so do not need interning into any
801 hashtables. */
802 case CTF_K_ARRAY:
803 case CTF_K_SLICE:
804 break;
805
806 case CTF_K_FUNCTION:
fe4c2d55
NA
807 if (!isroot)
808 break;
809
676c3ecb 810 err = ctf_hash_insert_type (fp->ctf_names.ctn_readonly, fp,
72f33921
NA
811 LCTF_INDEX_TO_TYPE (fp, id, child),
812 tp->ctt_name);
d851ecd3 813 if (err != 0)
72f33921
NA
814 return err;
815 break;
816
817 case CTF_K_STRUCT:
fe4c2d55
NA
818 if (size >= CTF_LSTRUCT_THRESH)
819 nlstructs++;
820
821 if (!isroot)
822 break;
823
676c3ecb 824 err = ctf_hash_define_type (fp->ctf_structs.ctn_readonly, fp,
72f33921
NA
825 LCTF_INDEX_TO_TYPE (fp, id, child),
826 tp->ctt_name);
827
d851ecd3 828 if (err != 0)
72f33921
NA
829 return err;
830
72f33921
NA
831 break;
832
833 case CTF_K_UNION:
fe4c2d55
NA
834 if (size >= CTF_LSTRUCT_THRESH)
835 nlunions++;
836
837 if (!isroot)
838 break;
839
676c3ecb 840 err = ctf_hash_define_type (fp->ctf_unions.ctn_readonly, fp,
72f33921
NA
841 LCTF_INDEX_TO_TYPE (fp, id, child),
842 tp->ctt_name);
843
d851ecd3 844 if (err != 0)
72f33921 845 return err;
72f33921
NA
846 break;
847
848 case CTF_K_ENUM:
fe4c2d55
NA
849 if (!isroot)
850 break;
851
676c3ecb 852 err = ctf_hash_define_type (fp->ctf_enums.ctn_readonly, fp,
72f33921
NA
853 LCTF_INDEX_TO_TYPE (fp, id, child),
854 tp->ctt_name);
855
d851ecd3 856 if (err != 0)
72f33921
NA
857 return err;
858 break;
859
860 case CTF_K_TYPEDEF:
fe4c2d55
NA
861 if (!isroot)
862 break;
863
676c3ecb 864 err = ctf_hash_insert_type (fp->ctf_names.ctn_readonly, fp,
72f33921
NA
865 LCTF_INDEX_TO_TYPE (fp, id, child),
866 tp->ctt_name);
d851ecd3 867 if (err != 0)
72f33921
NA
868 return err;
869 break;
870
871 case CTF_K_FORWARD:
676c3ecb
NA
872 {
873 ctf_names_t *np = ctf_name_table (fp, tp->ctt_type);
fe4c2d55
NA
874
875 if (!isroot)
876 break;
877
676c3ecb
NA
878 /* Only insert forward tags into the given hash if the type or tag
879 name is not already present. */
880 if (ctf_hash_lookup_type (np->ctn_readonly, fp, name) == 0)
881 {
882 err = ctf_hash_insert_type (np->ctn_readonly, fp,
883 LCTF_INDEX_TO_TYPE (fp, id, child),
884 tp->ctt_name);
885 if (err != 0)
886 return err;
887 }
888 break;
889 }
72f33921
NA
890
891 case CTF_K_POINTER:
892 /* If the type referenced by the pointer is in this CTF container,
893 then store the index of the pointer type in
894 fp->ctf_ptrtab[ index of referenced type ]. */
895
896 if (LCTF_TYPE_ISCHILD (fp, tp->ctt_type) == child
897 && LCTF_TYPE_TO_INDEX (fp, tp->ctt_type) <= fp->ctf_typemax)
898 fp->ctf_ptrtab[LCTF_TYPE_TO_INDEX (fp, tp->ctt_type)] = id;
899 /*FALLTHRU*/
900
901 case CTF_K_VOLATILE:
902 case CTF_K_CONST:
903 case CTF_K_RESTRICT:
fe4c2d55
NA
904 if (!isroot)
905 break;
906
676c3ecb 907 err = ctf_hash_insert_type (fp->ctf_names.ctn_readonly, fp,
72f33921
NA
908 LCTF_INDEX_TO_TYPE (fp, id, child),
909 tp->ctt_name);
d851ecd3 910 if (err != 0)
72f33921
NA
911 return err;
912 break;
0b4fa56e
NA
913 default:
914 ctf_dprintf ("unhandled CTF kind in endianness conversion -- %x\n",
915 kind);
916 return ECTF_CORRUPT;
72f33921
NA
917 }
918
919 *xp = (uint32_t) ((uintptr_t) tp - (uintptr_t) fp->ctf_buf);
920 tp = (ctf_type_t *) ((uintptr_t) tp + increment + vbytes);
921 }
922
923 ctf_dprintf ("%lu total types processed\n", fp->ctf_typemax);
676c3ecb
NA
924 ctf_dprintf ("%u enum names hashed\n",
925 ctf_hash_size (fp->ctf_enums.ctn_readonly));
72f33921 926 ctf_dprintf ("%u struct names hashed (%d long)\n",
676c3ecb 927 ctf_hash_size (fp->ctf_structs.ctn_readonly), nlstructs);
72f33921 928 ctf_dprintf ("%u union names hashed (%d long)\n",
676c3ecb
NA
929 ctf_hash_size (fp->ctf_unions.ctn_readonly), nlunions);
930 ctf_dprintf ("%u base type names hashed\n",
931 ctf_hash_size (fp->ctf_names.ctn_readonly));
72f33921
NA
932
933 /* Make an additional pass through the pointer table to find pointers that
934 point to anonymous typedef nodes. If we find one, modify the pointer table
935 so that the pointer is also known to point to the node that is referenced
936 by the anonymous typedef node. */
937
938 for (id = 1; id <= fp->ctf_typemax; id++)
939 {
940 if ((dst = fp->ctf_ptrtab[id]) != 0)
941 {
942 tp = LCTF_INDEX_TO_TYPEPTR (fp, id);
943
676c3ecb
NA
944 if (LCTF_INFO_KIND (fp, tp->ctt_info) == CTF_K_TYPEDEF
945 && strcmp (ctf_strptr (fp, tp->ctt_name), "") == 0
946 && LCTF_TYPE_ISCHILD (fp, tp->ctt_type) == child
947 && LCTF_TYPE_TO_INDEX (fp, tp->ctt_type) <= fp->ctf_typemax)
948 fp->ctf_ptrtab[LCTF_TYPE_TO_INDEX (fp, tp->ctt_type)] = dst;
72f33921
NA
949 }
950 }
951
952 return 0;
953}
954
955/* Endianness-flipping routines.
956
957 We flip everything, mindlessly, even 1-byte entities, so that future
958 expansions do not require changes to this code. */
959
960/* < C11? define away static assertions. */
961
962#if !defined (__STDC_VERSION__) || __STDC_VERSION__ < 201112L
963#define _Static_assert(cond, err)
964#endif
965
966/* Swap the endianness of something. */
967
968#define swap_thing(x) \
969 do { \
970 _Static_assert (sizeof (x) == 1 || (sizeof (x) % 2 == 0 \
971 && sizeof (x) <= 8), \
972 "Invalid size, update endianness code"); \
973 switch (sizeof (x)) { \
974 case 2: x = bswap_16 (x); break; \
975 case 4: x = bswap_32 (x); break; \
976 case 8: x = bswap_64 (x); break; \
977 case 1: /* Nothing needs doing */ \
978 break; \
979 } \
980 } while (0);
981
982/* Flip the endianness of the CTF header. */
983
984static void
985flip_header (ctf_header_t *cth)
986{
987 swap_thing (cth->cth_preamble.ctp_magic);
988 swap_thing (cth->cth_preamble.ctp_version);
989 swap_thing (cth->cth_preamble.ctp_flags);
990 swap_thing (cth->cth_parlabel);
991 swap_thing (cth->cth_parname);
fd55eae8 992 swap_thing (cth->cth_cuname);
72f33921
NA
993 swap_thing (cth->cth_objtoff);
994 swap_thing (cth->cth_funcoff);
2db912ba
NA
995 swap_thing (cth->cth_objtidxoff);
996 swap_thing (cth->cth_funcidxoff);
72f33921
NA
997 swap_thing (cth->cth_varoff);
998 swap_thing (cth->cth_typeoff);
999 swap_thing (cth->cth_stroff);
1000 swap_thing (cth->cth_strlen);
1001}
1002
1003/* Flip the endianness of the label section, an array of ctf_lblent_t. */
1004
1005static void
1006flip_lbls (void *start, size_t len)
1007{
1008 ctf_lblent_t *lbl = start;
5ae6af75 1009 ssize_t i;
72f33921 1010
5ae6af75 1011 for (i = len / sizeof (struct ctf_lblent); i > 0; lbl++, i--)
72f33921
NA
1012 {
1013 swap_thing (lbl->ctl_label);
1014 swap_thing (lbl->ctl_type);
1015 }
1016}
1017
2db912ba
NA
1018/* Flip the endianness of the data-object or function sections or their indexes,
1019 all arrays of uint32_t. (The function section has more internal structure,
1020 but that structure is an array of uint32_t, so can be treated as one big
1021 array for byte-swapping.) */
72f33921
NA
1022
1023static void
1024flip_objts (void *start, size_t len)
1025{
1026 uint32_t *obj = start;
5ae6af75 1027 ssize_t i;
72f33921 1028
5ae6af75 1029 for (i = len / sizeof (uint32_t); i > 0; obj++, i--)
72f33921
NA
1030 swap_thing (*obj);
1031}
1032
1033/* Flip the endianness of the variable section, an array of ctf_varent_t. */
1034
1035static void
1036flip_vars (void *start, size_t len)
1037{
1038 ctf_varent_t *var = start;
5ae6af75 1039 ssize_t i;
72f33921 1040
5ae6af75 1041 for (i = len / sizeof (struct ctf_varent); i > 0; var++, i--)
72f33921
NA
1042 {
1043 swap_thing (var->ctv_name);
1044 swap_thing (var->ctv_type);
1045 }
1046}
1047
1048/* Flip the endianness of the type section, a tagged array of ctf_type or
1049 ctf_stype followed by variable data. */
1050
1051static int
1052flip_types (void *start, size_t len)
1053{
1054 ctf_type_t *t = start;
1055
1056 while ((uintptr_t) t < ((uintptr_t) start) + len)
1057 {
1058 swap_thing (t->ctt_name);
1059 swap_thing (t->ctt_info);
1060 swap_thing (t->ctt_size);
1061
1062 uint32_t kind = CTF_V2_INFO_KIND (t->ctt_info);
1063 size_t size = t->ctt_size;
1064 uint32_t vlen = CTF_V2_INFO_VLEN (t->ctt_info);
1065 size_t vbytes = get_vbytes_v2 (kind, size, vlen);
1066
1067 if (_libctf_unlikely_ (size == CTF_LSIZE_SENT))
1068 {
1069 swap_thing (t->ctt_lsizehi);
1070 swap_thing (t->ctt_lsizelo);
1071 size = CTF_TYPE_LSIZE (t);
1072 t = (ctf_type_t *) ((uintptr_t) t + sizeof (ctf_type_t));
1073 }
1074 else
1075 t = (ctf_type_t *) ((uintptr_t) t + sizeof (ctf_stype_t));
1076
1077 switch (kind)
1078 {
1079 case CTF_K_FORWARD:
1080 case CTF_K_UNKNOWN:
1081 case CTF_K_POINTER:
1082 case CTF_K_TYPEDEF:
1083 case CTF_K_VOLATILE:
1084 case CTF_K_CONST:
1085 case CTF_K_RESTRICT:
1086 /* These types have no vlen data to swap. */
1087 assert (vbytes == 0);
1088 break;
1089
1090 case CTF_K_INTEGER:
1091 case CTF_K_FLOAT:
1092 {
1093 /* These types have a single uint32_t. */
1094
1095 uint32_t *item = (uint32_t *) t;
1096
1097 swap_thing (*item);
1098 break;
1099 }
1100
1101 case CTF_K_FUNCTION:
1102 {
1103 /* This type has a bunch of uint32_ts. */
1104
1105 uint32_t *item = (uint32_t *) t;
5ae6af75 1106 ssize_t i;
72f33921 1107
5ae6af75 1108 for (i = vlen; i > 0; item++, i--)
72f33921
NA
1109 swap_thing (*item);
1110 break;
1111 }
1112
1113 case CTF_K_ARRAY:
1114 {
1115 /* This has a single ctf_array_t. */
1116
1117 ctf_array_t *a = (ctf_array_t *) t;
1118
1119 assert (vbytes == sizeof (ctf_array_t));
1120 swap_thing (a->cta_contents);
1121 swap_thing (a->cta_index);
1122 swap_thing (a->cta_nelems);
1123
1124 break;
1125 }
1126
1127 case CTF_K_SLICE:
1128 {
1129 /* This has a single ctf_slice_t. */
1130
1131 ctf_slice_t *s = (ctf_slice_t *) t;
1132
1133 assert (vbytes == sizeof (ctf_slice_t));
1134 swap_thing (s->cts_type);
1135 swap_thing (s->cts_offset);
1136 swap_thing (s->cts_bits);
1137
1138 break;
1139 }
1140
1141 case CTF_K_STRUCT:
1142 case CTF_K_UNION:
1143 {
1144 /* This has an array of ctf_member or ctf_lmember, depending on
1145 size. We could consider it to be a simple array of uint32_t,
1146 but for safety's sake in case these structures ever acquire
1147 non-uint32_t members, do it member by member. */
1148
1149 if (_libctf_unlikely_ (size >= CTF_LSTRUCT_THRESH))
1150 {
1151 ctf_lmember_t *lm = (ctf_lmember_t *) t;
5ae6af75
NA
1152 ssize_t i;
1153 for (i = vlen; i > 0; i--, lm++)
72f33921
NA
1154 {
1155 swap_thing (lm->ctlm_name);
1156 swap_thing (lm->ctlm_offsethi);
1157 swap_thing (lm->ctlm_type);
1158 swap_thing (lm->ctlm_offsetlo);
1159 }
1160 }
1161 else
1162 {
1163 ctf_member_t *m = (ctf_member_t *) t;
5ae6af75
NA
1164 ssize_t i;
1165 for (i = vlen; i > 0; i--, m++)
72f33921
NA
1166 {
1167 swap_thing (m->ctm_name);
1168 swap_thing (m->ctm_offset);
1169 swap_thing (m->ctm_type);
1170 }
1171 }
1172 break;
1173 }
1174
1175 case CTF_K_ENUM:
1176 {
1177 /* This has an array of ctf_enum_t. */
1178
1179 ctf_enum_t *item = (ctf_enum_t *) t;
5ae6af75 1180 ssize_t i;
72f33921 1181
5ae6af75 1182 for (i = vlen; i > 0; item++, i--)
72f33921
NA
1183 {
1184 swap_thing (item->cte_name);
1185 swap_thing (item->cte_value);
1186 }
1187 break;
1188 }
1189 default:
1190 ctf_dprintf ("unhandled CTF kind in endianness conversion -- %x\n",
1191 kind);
1192 return ECTF_CORRUPT;
1193 }
1194
1195 t = (ctf_type_t *) ((uintptr_t) t + vbytes);
1196 }
1197
1198 return 0;
1199}
1200
fd55eae8 1201/* Flip the endianness of BUF, given the offsets in the (already endian-
72f33921
NA
1202 converted) CTH.
1203
1204 All of this stuff happens before the header is fully initialized, so the
1205 LCTF_*() macros cannot be used yet. Since we do not try to endian-convert v1
1206 data, this is no real loss. */
1207
1208static int
fd55eae8 1209flip_ctf (ctf_header_t *cth, unsigned char *buf)
72f33921 1210{
fd55eae8
NA
1211 flip_lbls (buf + cth->cth_lbloff, cth->cth_objtoff - cth->cth_lbloff);
1212 flip_objts (buf + cth->cth_objtoff, cth->cth_funcoff - cth->cth_objtoff);
2db912ba
NA
1213 flip_objts (buf + cth->cth_funcoff, cth->cth_objtidxoff - cth->cth_funcoff);
1214 flip_objts (buf + cth->cth_objtidxoff, cth->cth_funcidxoff - cth->cth_objtidxoff);
1215 flip_objts (buf + cth->cth_funcidxoff, cth->cth_varoff - cth->cth_funcidxoff);
fd55eae8
NA
1216 flip_vars (buf + cth->cth_varoff, cth->cth_typeoff - cth->cth_varoff);
1217 return flip_types (buf + cth->cth_typeoff, cth->cth_stroff - cth->cth_typeoff);
72f33921
NA
1218}
1219
676c3ecb
NA
1220/* Set up the ctl hashes in a ctf_file_t. Called by both writable and
1221 non-writable dictionary initialization. */
1222void ctf_set_ctl_hashes (ctf_file_t *fp)
1223{
1224 /* Initialize the ctf_lookup_by_name top-level dictionary. We keep an
1225 array of type name prefixes and the corresponding ctf_hash to use. */
1226 fp->ctf_lookups[0].ctl_prefix = "struct";
1227 fp->ctf_lookups[0].ctl_len = strlen (fp->ctf_lookups[0].ctl_prefix);
1228 fp->ctf_lookups[0].ctl_hash = &fp->ctf_structs;
1229 fp->ctf_lookups[1].ctl_prefix = "union";
1230 fp->ctf_lookups[1].ctl_len = strlen (fp->ctf_lookups[1].ctl_prefix);
1231 fp->ctf_lookups[1].ctl_hash = &fp->ctf_unions;
1232 fp->ctf_lookups[2].ctl_prefix = "enum";
1233 fp->ctf_lookups[2].ctl_len = strlen (fp->ctf_lookups[2].ctl_prefix);
1234 fp->ctf_lookups[2].ctl_hash = &fp->ctf_enums;
1235 fp->ctf_lookups[3].ctl_prefix = _CTF_NULLSTR;
1236 fp->ctf_lookups[3].ctl_len = strlen (fp->ctf_lookups[3].ctl_prefix);
1237 fp->ctf_lookups[3].ctl_hash = &fp->ctf_names;
1238 fp->ctf_lookups[4].ctl_prefix = NULL;
1239 fp->ctf_lookups[4].ctl_len = 0;
1240 fp->ctf_lookups[4].ctl_hash = NULL;
1241}
1242
72f33921 1243/* Open a CTF file, mocking up a suitable ctf_sect. */
d851ecd3 1244
72f33921
NA
1245ctf_file_t *ctf_simple_open (const char *ctfsect, size_t ctfsect_size,
1246 const char *symsect, size_t symsect_size,
1247 size_t symsect_entsize,
1248 const char *strsect, size_t strsect_size,
1249 int *errp)
d851ecd3
NA
1250{
1251 return ctf_simple_open_internal (ctfsect, ctfsect_size, symsect, symsect_size,
1252 symsect_entsize, strsect, strsect_size, NULL,
676c3ecb 1253 0, errp);
d851ecd3
NA
1254}
1255
1256/* Open a CTF file, mocking up a suitable ctf_sect and overriding the external
1257 strtab with a synthetic one. */
1258
1259ctf_file_t *ctf_simple_open_internal (const char *ctfsect, size_t ctfsect_size,
1260 const char *symsect, size_t symsect_size,
1261 size_t symsect_entsize,
1262 const char *strsect, size_t strsect_size,
676c3ecb
NA
1263 ctf_dynhash_t *syn_strtab, int writable,
1264 int *errp)
72f33921
NA
1265{
1266 ctf_sect_t skeleton;
1267
1268 ctf_sect_t ctf_sect, sym_sect, str_sect;
1269 ctf_sect_t *ctfsectp = NULL;
1270 ctf_sect_t *symsectp = NULL;
1271 ctf_sect_t *strsectp = NULL;
1272
1273 skeleton.cts_name = _CTF_SECTION;
72f33921 1274 skeleton.cts_entsize = 1;
72f33921
NA
1275
1276 if (ctfsect)
1277 {
1278 memcpy (&ctf_sect, &skeleton, sizeof (struct ctf_sect));
1279 ctf_sect.cts_data = ctfsect;
1280 ctf_sect.cts_size = ctfsect_size;
1281 ctfsectp = &ctf_sect;
1282 }
1283
1284 if (symsect)
1285 {
1286 memcpy (&sym_sect, &skeleton, sizeof (struct ctf_sect));
1287 sym_sect.cts_data = symsect;
1288 sym_sect.cts_size = symsect_size;
1289 sym_sect.cts_entsize = symsect_entsize;
1290 symsectp = &sym_sect;
1291 }
1292
1293 if (strsect)
1294 {
1295 memcpy (&str_sect, &skeleton, sizeof (struct ctf_sect));
1296 str_sect.cts_data = strsect;
1297 str_sect.cts_size = strsect_size;
1298 strsectp = &str_sect;
1299 }
1300
676c3ecb
NA
1301 return ctf_bufopen_internal (ctfsectp, symsectp, strsectp, syn_strtab,
1302 writable, errp);
72f33921
NA
1303}
1304
1305/* Decode the specified CTF buffer and optional symbol table, and create a new
1306 CTF container representing the symbolic debugging information. This code can
1307 be used directly by the debugger, or it can be used as the engine for
1308 ctf_fdopen() or ctf_open(), below. */
1309
1310ctf_file_t *
1311ctf_bufopen (const ctf_sect_t *ctfsect, const ctf_sect_t *symsect,
1312 const ctf_sect_t *strsect, int *errp)
d851ecd3 1313{
676c3ecb 1314 return ctf_bufopen_internal (ctfsect, symsect, strsect, NULL, 0, errp);
d851ecd3
NA
1315}
1316
1317/* Like ctf_bufopen, but overriding the external strtab with a synthetic one. */
1318
1319ctf_file_t *
1320ctf_bufopen_internal (const ctf_sect_t *ctfsect, const ctf_sect_t *symsect,
1321 const ctf_sect_t *strsect, ctf_dynhash_t *syn_strtab,
676c3ecb 1322 int writable, int *errp)
72f33921
NA
1323{
1324 const ctf_preamble_t *pp;
fd55eae8
NA
1325 size_t hdrsz = sizeof (ctf_header_t);
1326 ctf_header_t *hp;
72f33921 1327 ctf_file_t *fp;
72f33921
NA
1328 int foreign_endian = 0;
1329 int err;
1330
1331 libctf_init_debug();
1332
d851ecd3
NA
1333 if ((ctfsect == NULL) || ((symsect != NULL) &&
1334 ((strsect == NULL) && syn_strtab == NULL)))
72f33921
NA
1335 return (ctf_set_open_errno (errp, EINVAL));
1336
1337 if (symsect != NULL && symsect->cts_entsize != sizeof (Elf32_Sym) &&
1338 symsect->cts_entsize != sizeof (Elf64_Sym))
1339 return (ctf_set_open_errno (errp, ECTF_SYMTAB));
1340
1341 if (symsect != NULL && symsect->cts_data == NULL)
1342 return (ctf_set_open_errno (errp, ECTF_SYMBAD));
1343
1344 if (strsect != NULL && strsect->cts_data == NULL)
1345 return (ctf_set_open_errno (errp, ECTF_STRBAD));
1346
1347 if (ctfsect->cts_size < sizeof (ctf_preamble_t))
1348 return (ctf_set_open_errno (errp, ECTF_NOCTFBUF));
1349
1350 pp = (const ctf_preamble_t *) ctfsect->cts_data;
1351
1352 ctf_dprintf ("ctf_bufopen: magic=0x%x version=%u\n",
1353 pp->ctp_magic, pp->ctp_version);
1354
1355 /* Validate each part of the CTF header.
1356
1357 First, we validate the preamble (common to all versions). At that point,
1358 we know the endianness and specific header version, and can validate the
1359 version-specific parts including section offsets and alignments.
1360
1361 We specifically do not support foreign-endian old versions. */
1362
1363 if (_libctf_unlikely_ (pp->ctp_magic != CTF_MAGIC))
1364 {
1365 if (pp->ctp_magic == bswap_16 (CTF_MAGIC))
1366 {
1367 if (pp->ctp_version != CTF_VERSION_3)
1368 return (ctf_set_open_errno (errp, ECTF_CTFVERS));
1369 foreign_endian = 1;
1370 }
1371 else
1372 return (ctf_set_open_errno (errp, ECTF_NOCTFBUF));
1373 }
1374
1375 if (_libctf_unlikely_ ((pp->ctp_version < CTF_VERSION_1)
1376 || (pp->ctp_version > CTF_VERSION_3)))
1377 return (ctf_set_open_errno (errp, ECTF_CTFVERS));
1378
1379 if ((symsect != NULL) && (pp->ctp_version < CTF_VERSION_2))
1380 {
1381 /* The symtab can contain function entries which contain embedded ctf
1382 info. We do not support dynamically upgrading such entries (none
1383 should exist in any case, since dwarf2ctf does not create them). */
1384
1385 ctf_dprintf ("ctf_bufopen: CTF version %d symsect not "
1386 "supported\n", pp->ctp_version);
1387 return (ctf_set_open_errno (errp, ECTF_NOTSUP));
1388 }
1389
fd55eae8
NA
1390 if (pp->ctp_version < CTF_VERSION_3)
1391 hdrsz = sizeof (ctf_header_v2_t);
1392
1393 if (ctfsect->cts_size < hdrsz)
72f33921
NA
1394 return (ctf_set_open_errno (errp, ECTF_NOCTFBUF));
1395
de07e349 1396 if ((fp = malloc (sizeof (ctf_file_t))) == NULL)
fd55eae8
NA
1397 return (ctf_set_open_errno (errp, ENOMEM));
1398
1399 memset (fp, 0, sizeof (ctf_file_t));
1400
676c3ecb
NA
1401 if (writable)
1402 fp->ctf_flags |= LCTF_RDWR;
1403
de07e349 1404 if ((fp->ctf_header = malloc (sizeof (struct ctf_header))) == NULL)
fd55eae8 1405 {
de07e349 1406 free (fp);
fd55eae8
NA
1407 return (ctf_set_open_errno (errp, ENOMEM));
1408 }
1409 hp = fp->ctf_header;
1410 memcpy (hp, ctfsect->cts_data, hdrsz);
1411 if (pp->ctp_version < CTF_VERSION_3)
1412 upgrade_header (hp);
72f33921
NA
1413
1414 if (foreign_endian)
fd55eae8 1415 flip_header (hp);
9b32cba4 1416 fp->ctf_openflags = hp->cth_flags;
fd55eae8 1417 fp->ctf_size = hp->cth_stroff + hp->cth_strlen;
72f33921 1418
fd55eae8
NA
1419 ctf_dprintf ("ctf_bufopen: uncompressed size=%lu\n",
1420 (unsigned long) fp->ctf_size);
72f33921 1421
fd55eae8 1422 if (hp->cth_lbloff > fp->ctf_size || hp->cth_objtoff > fp->ctf_size
2db912ba
NA
1423 || hp->cth_funcoff > fp->ctf_size || hp->cth_objtidxoff > fp->ctf_size
1424 || hp->cth_funcidxoff > fp->ctf_size || hp->cth_typeoff > fp->ctf_size
fd55eae8 1425 || hp->cth_stroff > fp->ctf_size)
72f33921
NA
1426 return (ctf_set_open_errno (errp, ECTF_CORRUPT));
1427
fd55eae8
NA
1428 if (hp->cth_lbloff > hp->cth_objtoff
1429 || hp->cth_objtoff > hp->cth_funcoff
1430 || hp->cth_funcoff > hp->cth_typeoff
2db912ba
NA
1431 || hp->cth_funcoff > hp->cth_objtidxoff
1432 || hp->cth_objtidxoff > hp->cth_funcidxoff
1433 || hp->cth_funcidxoff > hp->cth_varoff
fd55eae8 1434 || hp->cth_varoff > hp->cth_typeoff || hp->cth_typeoff > hp->cth_stroff)
72f33921
NA
1435 return (ctf_set_open_errno (errp, ECTF_CORRUPT));
1436
fd55eae8 1437 if ((hp->cth_lbloff & 3) || (hp->cth_objtoff & 2)
2db912ba
NA
1438 || (hp->cth_funcoff & 2) || (hp->cth_objtidxoff & 2)
1439 || (hp->cth_funcidxoff & 2) || (hp->cth_varoff & 3)
fd55eae8 1440 || (hp->cth_typeoff & 3))
72f33921
NA
1441 return (ctf_set_open_errno (errp, ECTF_CORRUPT));
1442
1443 /* Once everything is determined to be valid, attempt to decompress the CTF
1444 data buffer if it is compressed, or copy it into new storage if it is not
1445 compressed but needs endian-flipping. Otherwise we just put the data
1446 section's buffer pointer into ctf_buf, below. */
1447
1448 /* Note: if this is a v1 buffer, it will be reallocated and expanded by
1449 init_types(). */
1450
fd55eae8 1451 if (hp->cth_flags & CTF_F_COMPRESS)
72f33921 1452 {
a0486bac
JM
1453 size_t srclen;
1454 uLongf dstlen;
72f33921
NA
1455 const void *src;
1456 int rc = Z_OK;
1457
fd55eae8
NA
1458 /* We are allocating this ourselves, so we can drop the ctf header
1459 copy in favour of ctf->ctf_header. */
72f33921 1460
de07e349 1461 if ((fp->ctf_base = malloc (fp->ctf_size)) == NULL)
fd55eae8
NA
1462 {
1463 err = ECTF_ZALLOC;
1464 goto bad;
1465 }
1466 fp->ctf_dynbase = fp->ctf_base;
1467 hp->cth_flags &= ~CTF_F_COMPRESS;
72f33921
NA
1468
1469 src = (unsigned char *) ctfsect->cts_data + hdrsz;
1470 srclen = ctfsect->cts_size - hdrsz;
fd55eae8
NA
1471 dstlen = fp->ctf_size;
1472 fp->ctf_buf = fp->ctf_base;
72f33921 1473
fd55eae8 1474 if ((rc = uncompress (fp->ctf_base, &dstlen, src, srclen)) != Z_OK)
72f33921
NA
1475 {
1476 ctf_dprintf ("zlib inflate err: %s\n", zError (rc));
fd55eae8
NA
1477 err = ECTF_DECOMPRESS;
1478 goto bad;
72f33921
NA
1479 }
1480
fd55eae8 1481 if ((size_t) dstlen != fp->ctf_size)
72f33921
NA
1482 {
1483 ctf_dprintf ("zlib inflate short -- got %lu of %lu "
fd55eae8
NA
1484 "bytes\n", (unsigned long) dstlen,
1485 (unsigned long) fp->ctf_size);
1486 err = ECTF_CORRUPT;
1487 goto bad;
72f33921 1488 }
72f33921
NA
1489 }
1490 else if (foreign_endian)
1491 {
de07e349 1492 if ((fp->ctf_base = malloc (fp->ctf_size)) == NULL)
fd55eae8
NA
1493 {
1494 err = ECTF_ZALLOC;
1495 goto bad;
1496 }
1497 fp->ctf_dynbase = fp->ctf_base;
1498 memcpy (fp->ctf_base, ((unsigned char *) ctfsect->cts_data) + hdrsz,
1499 fp->ctf_size);
1500 fp->ctf_buf = fp->ctf_base;
72f33921
NA
1501 }
1502 else
fd55eae8
NA
1503 {
1504 /* We are just using the section passed in -- but its header may be an old
1505 version. Point ctf_buf past the old header, and never touch it
1506 again. */
1507 fp->ctf_base = (unsigned char *) ctfsect->cts_data;
1508 fp->ctf_dynbase = NULL;
1509 fp->ctf_buf = fp->ctf_base + hdrsz;
1510 }
72f33921
NA
1511
1512 /* Once we have uncompressed and validated the CTF data buffer, we can
fd55eae8 1513 proceed with initializing the ctf_file_t we allocated above.
72f33921
NA
1514
1515 Nothing that depends on buf or base should be set directly in this function
1516 before the init_types() call, because it may be reallocated during
1517 transparent upgrade if this recension of libctf is so configured: see
fd55eae8 1518 ctf_set_base(). */
72f33921 1519
fd55eae8 1520 ctf_set_version (fp, hp, hp->cth_version);
f5e9c9bd 1521 ctf_str_create_atoms (fp);
fd55eae8 1522 fp->ctf_parmax = CTF_MAX_PTYPE;
72f33921
NA
1523 memcpy (&fp->ctf_data, ctfsect, sizeof (ctf_sect_t));
1524
1525 if (symsect != NULL)
1526 {
1527 memcpy (&fp->ctf_symtab, symsect, sizeof (ctf_sect_t));
1528 memcpy (&fp->ctf_strtab, strsect, sizeof (ctf_sect_t));
1529 }
1530
1531 if (fp->ctf_data.cts_name != NULL)
de07e349
NA
1532 if ((fp->ctf_data.cts_name = strdup (fp->ctf_data.cts_name)) == NULL)
1533 {
1534 err = ENOMEM;
1535 goto bad;
1536 }
72f33921 1537 if (fp->ctf_symtab.cts_name != NULL)
de07e349
NA
1538 if ((fp->ctf_symtab.cts_name = strdup (fp->ctf_symtab.cts_name)) == NULL)
1539 {
1540 err = ENOMEM;
1541 goto bad;
1542 }
72f33921 1543 if (fp->ctf_strtab.cts_name != NULL)
de07e349
NA
1544 if ((fp->ctf_strtab.cts_name = strdup (fp->ctf_strtab.cts_name)) == NULL)
1545 {
1546 err = ENOMEM;
1547 goto bad;
1548 }
72f33921
NA
1549
1550 if (fp->ctf_data.cts_name == NULL)
1551 fp->ctf_data.cts_name = _CTF_NULLSTR;
1552 if (fp->ctf_symtab.cts_name == NULL)
1553 fp->ctf_symtab.cts_name = _CTF_NULLSTR;
1554 if (fp->ctf_strtab.cts_name == NULL)
1555 fp->ctf_strtab.cts_name = _CTF_NULLSTR;
1556
1557 if (strsect != NULL)
1558 {
1559 fp->ctf_str[CTF_STRTAB_1].cts_strs = strsect->cts_data;
1560 fp->ctf_str[CTF_STRTAB_1].cts_len = strsect->cts_size;
1561 }
d851ecd3 1562 fp->ctf_syn_ext_strtab = syn_strtab;
72f33921
NA
1563
1564 if (foreign_endian &&
fd55eae8 1565 (err = flip_ctf (hp, fp->ctf_buf)) != 0)
72f33921
NA
1566 {
1567 /* We can be certain that flip_ctf() will have endian-flipped everything
fa56cdcd
NA
1568 other than the types table when we return. In particular the header
1569 is fine, so set it, to allow freeing to use the usual code path. */
72f33921 1570
fd55eae8 1571 ctf_set_base (fp, hp, fp->ctf_base);
72f33921
NA
1572 goto bad;
1573 }
1574
fd55eae8 1575 ctf_set_base (fp, hp, fp->ctf_base);
72f33921 1576
676c3ecb
NA
1577 /* No need to do anything else for dynamic containers: they do not support
1578 symbol lookups, and the type table is maintained in the dthashes. */
1579 if (fp->ctf_flags & LCTF_RDWR)
1580 {
1581 fp->ctf_refcnt = 1;
1582 return fp;
1583 }
1584
fd55eae8
NA
1585 if ((err = init_types (fp, hp)) != 0)
1586 goto bad;
72f33921 1587
72f33921 1588 /* If we have a symbol table section, allocate and initialize
fd55eae8
NA
1589 the symtab translation table, pointed to by ctf_sxlate. This table may be
1590 too large for the actual size of the object and function info sections: if
1591 so, ctf_nsyms will be adjusted and the excess will never be used. */
72f33921
NA
1592
1593 if (symsect != NULL)
1594 {
1595 fp->ctf_nsyms = symsect->cts_size / symsect->cts_entsize;
de07e349 1596 fp->ctf_sxlate = malloc (fp->ctf_nsyms * sizeof (uint32_t));
72f33921
NA
1597
1598 if (fp->ctf_sxlate == NULL)
1599 {
fd55eae8 1600 err = ENOMEM;
72f33921
NA
1601 goto bad;
1602 }
1603
fd55eae8
NA
1604 if ((err = init_symtab (fp, hp, symsect, strsect)) != 0)
1605 goto bad;
72f33921
NA
1606 }
1607
676c3ecb 1608 ctf_set_ctl_hashes (fp);
72f33921
NA
1609
1610 if (symsect != NULL)
1611 {
1612 if (symsect->cts_entsize == sizeof (Elf64_Sym))
1613 (void) ctf_setmodel (fp, CTF_MODEL_LP64);
1614 else
1615 (void) ctf_setmodel (fp, CTF_MODEL_ILP32);
1616 }
1617 else
1618 (void) ctf_setmodel (fp, CTF_MODEL_NATIVE);
1619
1620 fp->ctf_refcnt = 1;
1621 return fp;
1622
1623bad:
fd55eae8 1624 ctf_set_open_errno (errp, err);
72f33921
NA
1625 ctf_file_close (fp);
1626 return NULL;
1627}
1628
1629/* Close the specified CTF container and free associated data structures. Note
1630 that ctf_file_close() is a reference counted operation: if the specified file
1631 is the parent of other active containers, its reference count will be greater
1632 than one and it will be freed later when no active children exist. */
1633
1634void
1635ctf_file_close (ctf_file_t *fp)
1636{
1637 ctf_dtdef_t *dtd, *ntd;
1638 ctf_dvdef_t *dvd, *nvd;
1639
1640 if (fp == NULL)
1641 return; /* Allow ctf_file_close(NULL) to simplify caller code. */
1642
1643 ctf_dprintf ("ctf_file_close(%p) refcnt=%u\n", (void *) fp, fp->ctf_refcnt);
1644
1645 if (fp->ctf_refcnt > 1)
1646 {
1647 fp->ctf_refcnt--;
1648 return;
1649 }
1650
de07e349
NA
1651 free (fp->ctf_dyncuname);
1652 free (fp->ctf_dynparname);
fd55eae8 1653 ctf_file_close (fp->ctf_parent);
72f33921
NA
1654
1655 for (dtd = ctf_list_next (&fp->ctf_dtdefs); dtd != NULL; dtd = ntd)
1656 {
1657 ntd = ctf_list_next (dtd);
1658 ctf_dtd_delete (fp, dtd);
1659 }
1660 ctf_dynhash_destroy (fp->ctf_dthash);
676c3ecb
NA
1661 if (fp->ctf_flags & LCTF_RDWR)
1662 {
1663 ctf_dynhash_destroy (fp->ctf_structs.ctn_writable);
1664 ctf_dynhash_destroy (fp->ctf_unions.ctn_writable);
1665 ctf_dynhash_destroy (fp->ctf_enums.ctn_writable);
1666 ctf_dynhash_destroy (fp->ctf_names.ctn_writable);
1667 }
1668 else
1669 {
1670 ctf_hash_destroy (fp->ctf_structs.ctn_readonly);
1671 ctf_hash_destroy (fp->ctf_unions.ctn_readonly);
1672 ctf_hash_destroy (fp->ctf_enums.ctn_readonly);
1673 ctf_hash_destroy (fp->ctf_names.ctn_readonly);
1674 }
72f33921
NA
1675
1676 for (dvd = ctf_list_next (&fp->ctf_dvdefs); dvd != NULL; dvd = nvd)
1677 {
1678 nvd = ctf_list_next (dvd);
1679 ctf_dvd_delete (fp, dvd);
1680 }
1681 ctf_dynhash_destroy (fp->ctf_dvhash);
f5e9c9bd 1682 ctf_str_free_atoms (fp);
de07e349 1683 free (fp->ctf_tmp_typeslice);
72f33921 1684
fd55eae8 1685 if (fp->ctf_data.cts_name != _CTF_NULLSTR)
de07e349 1686 free ((char *) fp->ctf_data.cts_name);
72f33921 1687
fd55eae8 1688 if (fp->ctf_symtab.cts_name != _CTF_NULLSTR)
de07e349 1689 free ((char *) fp->ctf_symtab.cts_name);
72f33921 1690
fd55eae8 1691 if (fp->ctf_strtab.cts_name != _CTF_NULLSTR)
de07e349 1692 free ((char *) fp->ctf_strtab.cts_name);
72f33921
NA
1693 else if (fp->ctf_data_mmapped)
1694 ctf_munmap (fp->ctf_data_mmapped, fp->ctf_data_mmapped_len);
1695
de07e349 1696 free (fp->ctf_dynbase);
72f33921 1697
d851ecd3 1698 ctf_dynhash_destroy (fp->ctf_syn_ext_strtab);
72c83edd
NA
1699 ctf_dynhash_destroy (fp->ctf_link_inputs);
1700 ctf_dynhash_destroy (fp->ctf_link_outputs);
886453cb 1701 ctf_dynhash_destroy (fp->ctf_link_type_mapping);
49ea9b45 1702 ctf_dynhash_destroy (fp->ctf_link_cu_mapping);
99dc3ebd 1703 ctf_dynhash_destroy (fp->ctf_add_processing);
d851ecd3 1704
de07e349
NA
1705 free (fp->ctf_sxlate);
1706 free (fp->ctf_txlate);
1707 free (fp->ctf_ptrtab);
72f33921 1708
de07e349
NA
1709 free (fp->ctf_header);
1710 free (fp);
72f33921
NA
1711}
1712
143dce84
NA
1713/* The converse of ctf_open(). ctf_open() disguises whatever it opens as an
1714 archive, so closing one is just like closing an archive. */
1715void
1716ctf_close (ctf_archive_t *arc)
1717{
1718 ctf_arc_close (arc);
1719}
1720
9402cc59
NA
1721/* Get the CTF archive from which this ctf_file_t is derived. */
1722ctf_archive_t *
1723ctf_get_arc (const ctf_file_t *fp)
1724{
1725 return fp->ctf_archive;
1726}
1727
72f33921
NA
1728/* Return the ctfsect out of the core ctf_impl. Useful for freeing the
1729 ctfsect's data * after ctf_file_close(), which is why we return the actual
1730 structure, not a pointer to it, since that is likely to become a pointer to
1731 freed data before the return value is used under the expected use case of
1732 ctf_getsect()/ ctf_file_close()/free(). */
676c3ecb 1733ctf_sect_t
72f33921
NA
1734ctf_getdatasect (const ctf_file_t *fp)
1735{
1736 return fp->ctf_data;
1737}
1738
1739/* Return the CTF handle for the parent CTF container, if one exists.
1740 Otherwise return NULL to indicate this container has no imported parent. */
1741ctf_file_t *
1742ctf_parent_file (ctf_file_t *fp)
1743{
1744 return fp->ctf_parent;
1745}
1746
1747/* Return the name of the parent CTF container, if one exists. Otherwise
1748 return NULL to indicate this container is a root container. */
1749const char *
1750ctf_parent_name (ctf_file_t *fp)
1751{
1752 return fp->ctf_parname;
1753}
1754
1755/* Set the parent name. It is an error to call this routine without calling
1756 ctf_import() at some point. */
de07e349 1757int
72f33921
NA
1758ctf_parent_name_set (ctf_file_t *fp, const char *name)
1759{
1760 if (fp->ctf_dynparname != NULL)
de07e349 1761 free (fp->ctf_dynparname);
72f33921 1762
de07e349
NA
1763 if ((fp->ctf_dynparname = strdup (name)) == NULL)
1764 return (ctf_set_errno (fp, ENOMEM));
72f33921 1765 fp->ctf_parname = fp->ctf_dynparname;
de07e349 1766 return 0;
72f33921
NA
1767}
1768
fd55eae8
NA
1769/* Return the name of the compilation unit this CTF file applies to. Usually
1770 non-NULL only for non-parent containers. */
1771const char *
1772ctf_cuname (ctf_file_t *fp)
1773{
1774 return fp->ctf_cuname;
1775}
1776
1777/* Set the compilation unit name. */
de07e349 1778int
fd55eae8
NA
1779ctf_cuname_set (ctf_file_t *fp, const char *name)
1780{
1781 if (fp->ctf_dyncuname != NULL)
de07e349 1782 free (fp->ctf_dyncuname);
fd55eae8 1783
de07e349
NA
1784 if ((fp->ctf_dyncuname = strdup (name)) == NULL)
1785 return (ctf_set_errno (fp, ENOMEM));
fd55eae8 1786 fp->ctf_cuname = fp->ctf_dyncuname;
de07e349 1787 return 0;
fd55eae8
NA
1788}
1789
72f33921
NA
1790/* Import the types from the specified parent container by storing a pointer
1791 to it in ctf_parent and incrementing its reference count. Only one parent
1792 is allowed: if a parent already exists, it is replaced by the new parent. */
1793int
1794ctf_import (ctf_file_t *fp, ctf_file_t *pfp)
1795{
1796 if (fp == NULL || fp == pfp || (pfp != NULL && pfp->ctf_refcnt == 0))
1797 return (ctf_set_errno (fp, EINVAL));
1798
1799 if (pfp != NULL && pfp->ctf_dmodel != fp->ctf_dmodel)
1800 return (ctf_set_errno (fp, ECTF_DMODEL));
1801
1802 if (fp->ctf_parent != NULL)
de07e349 1803 {
ad613f1d 1804 fp->ctf_parent->ctf_refcnt--;
de07e349
NA
1805 ctf_file_close (fp->ctf_parent);
1806 fp->ctf_parent = NULL;
1807 }
72f33921
NA
1808
1809 if (pfp != NULL)
1810 {
de07e349 1811 int err;
72f33921
NA
1812
1813 if (fp->ctf_parname == NULL)
de07e349
NA
1814 if ((err = ctf_parent_name_set (fp, "PARENT")) < 0)
1815 return err;
1816
1817 fp->ctf_flags |= LCTF_CHILD;
1818 pfp->ctf_refcnt++;
72f33921 1819 }
ad613f1d 1820
72f33921
NA
1821 fp->ctf_parent = pfp;
1822 return 0;
1823}
1824
1825/* Set the data model constant for the CTF container. */
1826int
1827ctf_setmodel (ctf_file_t *fp, int model)
1828{
1829 const ctf_dmodel_t *dp;
1830
1831 for (dp = _libctf_models; dp->ctd_name != NULL; dp++)
1832 {
1833 if (dp->ctd_code == model)
1834 {
1835 fp->ctf_dmodel = dp;
1836 return 0;
1837 }
1838 }
1839
1840 return (ctf_set_errno (fp, EINVAL));
1841}
1842
1843/* Return the data model constant for the CTF container. */
1844int
1845ctf_getmodel (ctf_file_t *fp)
1846{
1847 return fp->ctf_dmodel->ctd_code;
1848}
1849
a0486bac
JM
1850/* The caller can hang an arbitrary pointer off each ctf_file_t using this
1851 function. */
72f33921
NA
1852void
1853ctf_setspecific (ctf_file_t *fp, void *data)
1854{
1855 fp->ctf_specific = data;
1856}
1857
a0486bac 1858/* Retrieve the arbitrary pointer again. */
72f33921
NA
1859void *
1860ctf_getspecific (ctf_file_t *fp)
1861{
1862 return fp->ctf_specific;
1863}
This page took 0.39354 seconds and 4 git commands to generate.