2 Copyright (C) 2019-2024 Free Software Foundation, Inc.
4 This file is part of libctf.
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
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.
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/>. */
23 #include <sys/types.h>
29 static const ctf_dmodel_t _libctf_models
[] = {
30 {"ILP32", CTF_MODEL_ILP32
, 4, 1, 2, 4, 4},
31 {"LP64", CTF_MODEL_LP64
, 8, 1, 2, 4, 8},
32 {NULL
, 0, 0, 0, 0, 0, 0}
35 const char _CTF_SECTION
[] = ".ctf";
36 const char _CTF_NULLSTR
[] = "";
38 /* Version-sensitive accessors. */
41 get_kind_v1 (uint32_t info
)
43 return (CTF_V1_INFO_KIND (info
));
47 get_root_v1 (uint32_t info
)
49 return (CTF_V1_INFO_ISROOT (info
));
53 get_vlen_v1 (uint32_t info
)
55 return (CTF_V1_INFO_VLEN (info
));
59 get_kind_v2 (uint32_t info
)
61 return (CTF_V2_INFO_KIND (info
));
65 get_root_v2 (uint32_t info
)
67 return (CTF_V2_INFO_ISROOT (info
));
71 get_vlen_v2 (uint32_t info
)
73 return (CTF_V2_INFO_VLEN (info
));
77 get_ctt_size_common (const ctf_dict_t
*fp _libctf_unused_
,
78 const ctf_type_t
*tp _libctf_unused_
,
79 ssize_t
*sizep
, ssize_t
*incrementp
, size_t lsize
,
80 size_t csize
, size_t ctf_type_size
,
81 size_t ctf_stype_size
, size_t ctf_lsize_sent
)
83 ssize_t size
, increment
;
85 if (csize
== ctf_lsize_sent
)
88 increment
= ctf_type_size
;
93 increment
= ctf_stype_size
;
99 *incrementp
= increment
;
105 get_ctt_size_v1 (const ctf_dict_t
*fp
, const ctf_type_t
*tp
,
106 ssize_t
*sizep
, ssize_t
*incrementp
)
108 ctf_type_v1_t
*t1p
= (ctf_type_v1_t
*) tp
;
110 return (get_ctt_size_common (fp
, tp
, sizep
, incrementp
,
111 CTF_TYPE_LSIZE (t1p
), t1p
->ctt_size
,
112 sizeof (ctf_type_v1_t
), sizeof (ctf_stype_v1_t
),
116 /* Return the size that a v1 will be once it is converted to v2. */
119 get_ctt_size_v2_unconverted (const ctf_dict_t
*fp
, const ctf_type_t
*tp
,
120 ssize_t
*sizep
, ssize_t
*incrementp
)
122 ctf_type_v1_t
*t1p
= (ctf_type_v1_t
*) tp
;
124 return (get_ctt_size_common (fp
, tp
, sizep
, incrementp
,
125 CTF_TYPE_LSIZE (t1p
), t1p
->ctt_size
,
126 sizeof (ctf_type_t
), sizeof (ctf_stype_t
),
131 get_ctt_size_v2 (const ctf_dict_t
*fp
, const ctf_type_t
*tp
,
132 ssize_t
*sizep
, ssize_t
*incrementp
)
134 return (get_ctt_size_common (fp
, tp
, sizep
, incrementp
,
135 CTF_TYPE_LSIZE (tp
), tp
->ctt_size
,
136 sizeof (ctf_type_t
), sizeof (ctf_stype_t
),
141 get_vbytes_common (ctf_dict_t
*fp
, unsigned short kind
,
142 ssize_t size _libctf_unused_
, size_t vlen
)
148 return (sizeof (uint32_t));
150 return (sizeof (ctf_slice_t
));
152 return (sizeof (ctf_enum_t
) * vlen
);
162 ctf_set_errno (fp
, ECTF_CORRUPT
);
163 ctf_err_warn (fp
, 0, 0, _("detected invalid CTF kind: %x"), kind
);
169 get_vbytes_v1 (ctf_dict_t
*fp
, unsigned short kind
, ssize_t size
, size_t vlen
)
174 return (sizeof (ctf_array_v1_t
));
176 return (sizeof (unsigned short) * (vlen
+ (vlen
& 1)));
179 if (size
< CTF_LSTRUCT_THRESH_V1
)
180 return (sizeof (ctf_member_v1_t
) * vlen
);
182 return (sizeof (ctf_lmember_v1_t
) * vlen
);
185 return (get_vbytes_common (fp
, kind
, size
, vlen
));
189 get_vbytes_v2 (ctf_dict_t
*fp
, unsigned short kind
, ssize_t size
, size_t vlen
)
194 return (sizeof (ctf_array_t
));
196 return (sizeof (uint32_t) * (vlen
+ (vlen
& 1)));
199 if (size
< CTF_LSTRUCT_THRESH
)
200 return (sizeof (ctf_member_t
) * vlen
);
202 return (sizeof (ctf_lmember_t
) * vlen
);
205 return (get_vbytes_common (fp
, kind
, size
, vlen
));
208 static const ctf_dictops_t ctf_dictops
[] = {
209 {NULL
, NULL
, NULL
, NULL
, NULL
},
211 {get_kind_v1
, get_root_v1
, get_vlen_v1
, get_ctt_size_v1
, get_vbytes_v1
},
212 /* CTF_VERSION_1_UPGRADED_3 */
213 {get_kind_v2
, get_root_v2
, get_vlen_v2
, get_ctt_size_v2
, get_vbytes_v2
},
215 {get_kind_v2
, get_root_v2
, get_vlen_v2
, get_ctt_size_v2
, get_vbytes_v2
},
216 /* CTF_VERSION_3, identical to 2: only new type kinds */
217 {get_kind_v2
, get_root_v2
, get_vlen_v2
, get_ctt_size_v2
, get_vbytes_v2
},
220 /* Initialize the symtab translation table as appropriate for its indexing
221 state. For unindexed symtypetabs, fill each entry with the offset of the CTF
222 type or function data corresponding to each STT_FUNC or STT_OBJECT entry in
223 the symbol table. For indexed symtypetabs, do nothing: the needed
224 initialization for indexed lookups may be quite expensive, so it is done only
225 as needed, when lookups happen. (In particular, the majority of indexed
226 symtypetabs come from the compiler, and all the linker does is iteration over
227 all entries, which doesn't need this initialization.)
229 The SP symbol table section may be NULL if there is no symtab.
231 If init_symtab works on one call, it cannot fail on future calls to the same
232 fp: ctf_symsect_endianness relies on this. */
235 init_symtab (ctf_dict_t
*fp
, const ctf_header_t
*hp
, const ctf_sect_t
*sp
)
237 const unsigned char *symp
;
238 int skip_func_info
= 0;
240 uint32_t *xp
= fp
->ctf_sxlate
;
241 uint32_t *xend
= PTR_ADD (xp
, fp
->ctf_nsyms
);
243 uint32_t objtoff
= hp
->cth_objtoff
;
244 uint32_t funcoff
= hp
->cth_funcoff
;
246 /* If the CTF_F_NEWFUNCINFO flag is not set, pretend the func info section
247 is empty: this compiler is too old to emit a function info section we
250 if (!(hp
->cth_flags
& CTF_F_NEWFUNCINFO
))
253 if (hp
->cth_objtidxoff
< hp
->cth_funcidxoff
)
254 fp
->ctf_objtidx_names
= (uint32_t *) (fp
->ctf_buf
+ hp
->cth_objtidxoff
);
255 if (hp
->cth_funcidxoff
< hp
->cth_varoff
&& !skip_func_info
)
256 fp
->ctf_funcidx_names
= (uint32_t *) (fp
->ctf_buf
+ hp
->cth_funcidxoff
);
258 /* Don't bother doing the rest if everything is indexed, or if we don't have a
259 symbol table: we will never use it. */
260 if ((fp
->ctf_objtidx_names
&& fp
->ctf_funcidx_names
) || !sp
|| !sp
->cts_data
)
263 /* The CTF data object and function type sections are ordered to match the
264 relative order of the respective symbol types in the symtab, unless there
265 is an index section, in which case the order is arbitrary and the index
266 gives the mapping. If no type information is available for a symbol table
267 entry, a pad is inserted in the CTF section. As a further optimization,
268 anonymous or undefined symbols are omitted from the CTF data. If an
269 index is available for function symbols but not object symbols, or vice
270 versa, we populate the xslate table for the unindexed symbols only. */
272 for (i
= 0, symp
= sp
->cts_data
; xp
< xend
; xp
++, symp
+= sp
->cts_entsize
,
277 switch (sp
->cts_entsize
)
279 case sizeof (Elf64_Sym
):
281 const Elf64_Sym
*symp64
= (Elf64_Sym
*) (uintptr_t) symp
;
282 ctf_elf64_to_link_sym (fp
, &sym
, symp64
, i
);
285 case sizeof (Elf32_Sym
):
287 const Elf32_Sym
*symp32
= (Elf32_Sym
*) (uintptr_t) symp
;
288 ctf_elf32_to_link_sym (fp
, &sym
, symp32
, i
);
295 /* This call may be led astray if our idea of the symtab's endianness is
296 wrong, but when this is fixed by a call to ctf_symsect_endianness,
297 init_symtab will be called again with the right endianness in
299 if (ctf_symtab_skippable (&sym
))
308 if (fp
->ctf_objtidx_names
|| objtoff
>= hp
->cth_funcoff
)
315 objtoff
+= sizeof (uint32_t);
319 if (fp
->ctf_funcidx_names
|| funcoff
>= hp
->cth_objtidxoff
327 funcoff
+= sizeof (uint32_t);
336 ctf_dprintf ("loaded %lu symtab entries\n", fp
->ctf_nsyms
);
340 /* Reset the CTF base pointer and derive the buf pointer from it, initializing
341 everything in the ctf_dict that depends on the base or buf pointers.
343 The original gap between the buf and base pointers, if any -- the original,
344 unconverted CTF header -- is kept, but its contents are not specified and are
348 ctf_set_base (ctf_dict_t
*fp
, const ctf_header_t
*hp
, unsigned char *base
)
350 fp
->ctf_buf
= base
+ (fp
->ctf_buf
- fp
->ctf_base
);
352 fp
->ctf_vars
= (ctf_varent_t
*) ((const char *) fp
->ctf_buf
+
354 fp
->ctf_nvars
= (hp
->cth_typeoff
- hp
->cth_varoff
) / sizeof (ctf_varent_t
);
356 fp
->ctf_str
[CTF_STRTAB_0
].cts_strs
= (const char *) fp
->ctf_buf
358 fp
->ctf_str
[CTF_STRTAB_0
].cts_len
= hp
->cth_strlen
;
360 /* If we have a parent dict name and label, store the relocated string
361 pointers in the CTF dict for easy access later. */
363 /* Note: before conversion, these will be set to values that will be
364 immediately invalidated by the conversion process, but the conversion
365 process will call ctf_set_base() again to fix things up. */
367 if (hp
->cth_parlabel
!= 0)
368 fp
->ctf_parlabel
= ctf_strptr (fp
, hp
->cth_parlabel
);
369 if (hp
->cth_parname
!= 0)
370 fp
->ctf_parname
= ctf_strptr (fp
, hp
->cth_parname
);
371 if (hp
->cth_cuname
!= 0)
372 fp
->ctf_cuname
= ctf_strptr (fp
, hp
->cth_cuname
);
375 ctf_dprintf ("ctf_set_base: CU name %s\n", fp
->ctf_cuname
);
377 ctf_dprintf ("ctf_set_base: parent name %s (label %s)\n",
379 fp
->ctf_parlabel
? fp
->ctf_parlabel
: "<NULL>");
382 /* Set the version of the CTF file. */
384 /* When this is reset, LCTF_* changes behaviour, but there is no guarantee that
385 the variable data list associated with each type has been upgraded: the
386 caller must ensure this has been done in advance. */
389 ctf_set_version (ctf_dict_t
*fp
, ctf_header_t
*cth
, int ctf_version
)
391 fp
->ctf_version
= ctf_version
;
392 cth
->cth_version
= ctf_version
;
393 fp
->ctf_dictops
= &ctf_dictops
[ctf_version
];
397 /* Upgrade the header to CTF_VERSION_3. The upgrade is done in-place. */
399 upgrade_header (ctf_header_t
*hp
)
401 ctf_header_v2_t
*oldhp
= (ctf_header_v2_t
*) hp
;
403 hp
->cth_strlen
= oldhp
->cth_strlen
;
404 hp
->cth_stroff
= oldhp
->cth_stroff
;
405 hp
->cth_typeoff
= oldhp
->cth_typeoff
;
406 hp
->cth_varoff
= oldhp
->cth_varoff
;
407 hp
->cth_funcidxoff
= hp
->cth_varoff
; /* No index sections. */
408 hp
->cth_objtidxoff
= hp
->cth_funcidxoff
;
409 hp
->cth_funcoff
= oldhp
->cth_funcoff
;
410 hp
->cth_objtoff
= oldhp
->cth_objtoff
;
411 hp
->cth_lbloff
= oldhp
->cth_lbloff
;
412 hp
->cth_cuname
= 0; /* No CU name. */
415 /* Upgrade the type table to CTF_VERSION_3 (really CTF_VERSION_1_UPGRADED_3)
418 The upgrade is not done in-place: the ctf_base is moved. ctf_strptr() must
419 not be called before reallocation is complete.
421 Sections not checked here due to nonexistence or nonpopulated state in older
422 formats: objtidx, funcidx.
424 Type kinds not checked here due to nonexistence in older formats:
427 upgrade_types_v1 (ctf_dict_t
*fp
, ctf_header_t
*cth
)
429 const ctf_type_v1_t
*tbuf
;
430 const ctf_type_v1_t
*tend
;
431 unsigned char *ctf_base
, *old_ctf_base
= (unsigned char *) fp
->ctf_dynbase
;
434 ssize_t increase
= 0, size
, increment
, v2increment
, vbytes
, v2bytes
;
435 const ctf_type_v1_t
*tp
;
438 tbuf
= (ctf_type_v1_t
*) (fp
->ctf_buf
+ cth
->cth_typeoff
);
439 tend
= (ctf_type_v1_t
*) (fp
->ctf_buf
+ cth
->cth_stroff
);
441 /* Much like init_static_types(), this is a two-pass process.
443 First, figure out the new type-section size needed. (It is possible,
444 in theory, for it to be less than the old size, but this is very
445 unlikely. It cannot be so small that cth_typeoff ends up of negative
446 size. We validate this with an assertion below.)
448 We must cater not only for changes in vlen and types sizes but also
449 for changes in 'increment', which happen because v2 places some types
450 into ctf_stype_t where v1 would be forced to use the larger non-stype. */
452 for (tp
= tbuf
; tp
< tend
;
453 tp
= (ctf_type_v1_t
*) ((uintptr_t) tp
+ increment
+ vbytes
))
455 unsigned short kind
= CTF_V1_INFO_KIND (tp
->ctt_info
);
456 unsigned long vlen
= CTF_V1_INFO_VLEN (tp
->ctt_info
);
458 size
= get_ctt_size_v1 (fp
, (const ctf_type_t
*) tp
, NULL
, &increment
);
459 vbytes
= get_vbytes_v1 (fp
, kind
, size
, vlen
);
461 get_ctt_size_v2_unconverted (fp
, (const ctf_type_t
*) tp
, NULL
,
463 v2bytes
= get_vbytes_v2 (fp
, kind
, size
, vlen
);
465 if ((vbytes
< 0) || (size
< 0))
468 increase
+= v2increment
- increment
; /* May be negative. */
469 increase
+= v2bytes
- vbytes
;
472 /* Allocate enough room for the new buffer, then copy everything but the type
473 section into place, and reset the base accordingly. Leave the version
474 number unchanged, so that LCTF_INFO_* still works on the
475 as-yet-untranslated type info. */
477 if ((ctf_base
= malloc (fp
->ctf_size
+ increase
)) == NULL
)
480 /* Start at ctf_buf, not ctf_base, to squeeze out the original header: we
481 never use it and it is unconverted. */
483 memcpy (ctf_base
, fp
->ctf_buf
, cth
->cth_typeoff
);
484 memcpy (ctf_base
+ cth
->cth_stroff
+ increase
,
485 fp
->ctf_buf
+ cth
->cth_stroff
, cth
->cth_strlen
);
487 memset (ctf_base
+ cth
->cth_typeoff
, 0, cth
->cth_stroff
- cth
->cth_typeoff
490 cth
->cth_stroff
+= increase
;
491 fp
->ctf_size
+= increase
;
492 assert (cth
->cth_stroff
>= cth
->cth_typeoff
);
493 fp
->ctf_base
= ctf_base
;
494 fp
->ctf_buf
= ctf_base
;
495 fp
->ctf_dynbase
= ctf_base
;
496 ctf_set_base (fp
, cth
, ctf_base
);
498 t2buf
= (ctf_type_t
*) (fp
->ctf_buf
+ cth
->cth_typeoff
);
500 /* Iterate through all the types again, upgrading them.
502 Everything that hasn't changed can just be outright memcpy()ed.
503 Things that have changed need field-by-field consideration. */
505 for (tp
= tbuf
, t2p
= t2buf
; tp
< tend
;
506 tp
= (ctf_type_v1_t
*) ((uintptr_t) tp
+ increment
+ vbytes
),
507 t2p
= (ctf_type_t
*) ((uintptr_t) t2p
+ v2increment
+ v2bytes
))
509 unsigned short kind
= CTF_V1_INFO_KIND (tp
->ctt_info
);
510 int isroot
= CTF_V1_INFO_ISROOT (tp
->ctt_info
);
511 unsigned long vlen
= CTF_V1_INFO_VLEN (tp
->ctt_info
);
513 void *vdata
, *v2data
;
515 size
= get_ctt_size_v1 (fp
, (const ctf_type_t
*) tp
, NULL
, &increment
);
516 vbytes
= get_vbytes_v1 (fp
, kind
, size
, vlen
);
518 t2p
->ctt_name
= tp
->ctt_name
;
519 t2p
->ctt_info
= CTF_TYPE_INFO (kind
, isroot
, vlen
);
530 t2p
->ctt_type
= tp
->ctt_type
;
539 if ((size_t) size
<= CTF_MAX_SIZE
)
540 t2p
->ctt_size
= size
;
543 t2p
->ctt_lsizehi
= CTF_SIZE_TO_LSIZE_HI (size
);
544 t2p
->ctt_lsizelo
= CTF_SIZE_TO_LSIZE_LO (size
);
549 v2size
= get_ctt_size_v2 (fp
, t2p
, NULL
, &v2increment
);
550 v2bytes
= get_vbytes_v2 (fp
, kind
, v2size
, vlen
);
552 /* Catch out-of-sync get_ctt_size_*(). The count goes wrong if
553 these are not identical (and having them different makes no
554 sense semantically). */
556 assert (size
== v2size
);
558 /* Now the varlen info. */
560 vdata
= (void *) ((uintptr_t) tp
+ increment
);
561 v2data
= (void *) ((uintptr_t) t2p
+ v2increment
);
567 const ctf_array_v1_t
*ap
= (const ctf_array_v1_t
*) vdata
;
568 ctf_array_t
*a2p
= (ctf_array_t
*) v2data
;
570 a2p
->cta_contents
= ap
->cta_contents
;
571 a2p
->cta_index
= ap
->cta_index
;
572 a2p
->cta_nelems
= ap
->cta_nelems
;
579 const ctf_member_v1_t
*m1
= (const ctf_member_v1_t
*) vdata
;
580 const ctf_lmember_v1_t
*lm1
= (const ctf_lmember_v1_t
*) m1
;
581 ctf_member_t
*m2
= (ctf_member_t
*) v2data
;
582 ctf_lmember_t
*lm2
= (ctf_lmember_t
*) m2
;
585 /* We walk all four pointers forward, but only reference the two
586 that are valid for the given size, to avoid quadruplicating all
589 for (i
= vlen
; i
!= 0; i
--, m1
++, lm1
++, m2
++, lm2
++)
592 if (size
< CTF_LSTRUCT_THRESH_V1
)
594 offset
= m1
->ctm_offset
;
595 tmp
.ctm_name
= m1
->ctm_name
;
596 tmp
.ctm_type
= m1
->ctm_type
;
600 offset
= CTF_LMEM_OFFSET (lm1
);
601 tmp
.ctm_name
= lm1
->ctlm_name
;
602 tmp
.ctm_type
= lm1
->ctlm_type
;
604 if (size
< CTF_LSTRUCT_THRESH
)
606 m2
->ctm_name
= tmp
.ctm_name
;
607 m2
->ctm_type
= tmp
.ctm_type
;
608 m2
->ctm_offset
= offset
;
612 lm2
->ctlm_name
= tmp
.ctm_name
;
613 lm2
->ctlm_type
= tmp
.ctm_type
;
614 lm2
->ctlm_offsethi
= CTF_OFFSET_TO_LMEMHI (offset
);
615 lm2
->ctlm_offsetlo
= CTF_OFFSET_TO_LMEMLO (offset
);
623 unsigned short *a1
= (unsigned short *) vdata
;
624 uint32_t *a2
= (uint32_t *) v2data
;
626 for (i
= vlen
; i
!= 0; i
--, a1
++, a2
++)
631 /* Catch out-of-sync get_vbytes_*(). */
632 assert (vbytes
== v2bytes
);
633 memcpy (v2data
, vdata
, vbytes
);
637 /* Verify that the entire region was converted. If not, we are either
638 converting too much, or too little (leading to a buffer overrun either here
639 or at read time, in init_static_types().) */
641 assert ((size_t) t2p
- (size_t) fp
->ctf_buf
== cth
->cth_stroff
);
643 ctf_set_version (fp
, cth
, CTF_VERSION_1_UPGRADED_3
);
649 /* Upgrade from any earlier version. */
651 upgrade_types (ctf_dict_t
*fp
, ctf_header_t
*cth
)
653 switch (cth
->cth_version
)
655 /* v1 requires a full pass and reformatting. */
657 upgrade_types_v1 (fp
, cth
);
659 /* Already-converted v1 is just like later versions except that its
660 parent/child boundary is unchanged (and much lower). */
662 case CTF_VERSION_1_UPGRADED_3
:
663 fp
->ctf_parmax
= CTF_MAX_PTYPE_V1
;
665 /* v2 is just the same as v3 except for new types and sections:
666 no upgrading required. */
667 case CTF_VERSION_2
: ;
674 init_static_types_internal (ctf_dict_t
*fp
, ctf_header_t
*cth
,
675 ctf_dynset_t
*all_enums
);
677 /* Populate statically-defined types (those loaded from a saved buffer).
679 Initialize the type ID translation table with the byte offset of each type,
680 and initialize the hash tables of each named type. Upgrade the type table to
681 the latest supported representation in the process, if needed, and if this
682 recension of libctf supports upgrading.
684 Returns zero on success and a *positive* ECTF_* or errno value on error.
686 This is a wrapper to simplify memory allocation on error in the _internal
687 function that does all the actual work. */
690 init_static_types (ctf_dict_t
*fp
, ctf_header_t
*cth
)
692 ctf_dynset_t
*all_enums
;
695 if ((all_enums
= ctf_dynset_create (htab_hash_pointer
, htab_eq_pointer
,
699 err
= init_static_types_internal (fp
, cth
, all_enums
);
700 ctf_dynset_destroy (all_enums
);
705 init_static_types_internal (ctf_dict_t
*fp
, ctf_header_t
*cth
,
706 ctf_dynset_t
*all_enums
)
708 const ctf_type_t
*tbuf
;
709 const ctf_type_t
*tend
;
711 unsigned long pop
[CTF_K_MAX
+ 1] = { 0 };
712 int pop_enumerators
= 0;
713 const ctf_type_t
*tp
;
716 unsigned long typemax
= 0;
717 ctf_next_t
*i
= NULL
;
720 /* We determine whether the dict is a child or a parent based on the value of
723 int child
= cth
->cth_parname
!= 0;
724 int nlstructs
= 0, nlunions
= 0;
727 if (_libctf_unlikely_ (fp
->ctf_version
== CTF_VERSION_1
))
730 if ((err
= upgrade_types (fp
, cth
)) != 0)
731 return err
; /* Upgrade failed. */
734 tbuf
= (ctf_type_t
*) (fp
->ctf_buf
+ cth
->cth_typeoff
);
735 tend
= (ctf_type_t
*) (fp
->ctf_buf
+ cth
->cth_stroff
);
737 /* We make two passes through the entire type section, and one third pass
738 through part of it. In this first pass, we count the number of each type
739 and type-like identifier (like enumerators) and the total number of
742 for (tp
= tbuf
; tp
< tend
; typemax
++)
744 unsigned short kind
= LCTF_INFO_KIND (fp
, tp
->ctt_info
);
745 unsigned long vlen
= LCTF_INFO_VLEN (fp
, tp
->ctt_info
);
746 ssize_t size
, increment
, vbytes
;
748 (void) ctf_get_ctt_size (fp
, tp
, &size
, &increment
);
749 vbytes
= LCTF_VBYTES (fp
, kind
, size
, vlen
);
754 /* For forward declarations, ctt_type is the CTF_K_* kind for the tag,
755 so bump that population count too. */
756 if (kind
== CTF_K_FORWARD
)
759 tp
= (ctf_type_t
*) ((uintptr_t) tp
+ increment
+ vbytes
);
762 if (kind
== CTF_K_ENUM
)
763 pop_enumerators
+= vlen
;
768 ctf_dprintf ("CTF dict %p is a child\n", (void *) fp
);
769 fp
->ctf_flags
|= LCTF_CHILD
;
772 ctf_dprintf ("CTF dict %p is a parent\n", (void *) fp
);
774 /* Now that we've counted up the number of each type, we can allocate
775 the hash tables, type translation table, and pointer table. */
778 = ctf_dynhash_create_sized (pop
[CTF_K_STRUCT
], ctf_hash_string
,
779 ctf_hash_eq_string
, NULL
, NULL
)) == NULL
)
783 = ctf_dynhash_create_sized (pop
[CTF_K_UNION
], ctf_hash_string
,
784 ctf_hash_eq_string
, NULL
, NULL
)) == NULL
)
788 = ctf_dynhash_create_sized (pop
[CTF_K_ENUM
], ctf_hash_string
,
789 ctf_hash_eq_string
, NULL
, NULL
)) == NULL
)
793 = ctf_dynhash_create_sized (pop
[CTF_K_UNKNOWN
] +
796 pop
[CTF_K_FUNCTION
] +
799 pop
[CTF_K_VOLATILE
] +
801 pop
[CTF_K_RESTRICT
] +
804 ctf_hash_eq_string
, NULL
, NULL
)) == NULL
)
807 if ((fp
->ctf_conflicting_enums
808 = ctf_dynset_create (htab_hash_string
, htab_eq_string
, NULL
)) == NULL
)
811 /* The ptrtab and txlate can be appropriately sized for precisely this set
812 of types: the txlate because it is only used to look up static types,
813 so dynamic types added later will never go through it, and the ptrtab
814 because later-added types will call grow_ptrtab() automatically, as
817 fp
->ctf_txlate
= malloc (sizeof (uint32_t) * (typemax
+ 1));
818 fp
->ctf_ptrtab_len
= typemax
+ 1;
819 fp
->ctf_ptrtab
= malloc (sizeof (uint32_t) * fp
->ctf_ptrtab_len
);
820 fp
->ctf_stypes
= typemax
;
822 if (fp
->ctf_txlate
== NULL
|| fp
->ctf_ptrtab
== NULL
)
823 return ENOMEM
; /* Memory allocation failed. */
826 *xp
++ = 0; /* Type id 0 is used as a sentinel value. */
828 memset (fp
->ctf_txlate
, 0, sizeof (uint32_t) * (typemax
+ 1));
829 memset (fp
->ctf_ptrtab
, 0, sizeof (uint32_t) * (typemax
+ 1));
831 /* In the second pass through the types, we fill in each entry of the
832 type and pointer tables and add names to the appropriate hashes.
834 (Not all names are added in this pass, only type names. See below.)
836 Bump ctf_typemax as we go, but keep it one higher than normal, so that
837 the type being read in is considered a valid type and it is at least
838 barely possible to run simple lookups on it. */
840 for (id
= 1, fp
->ctf_typemax
= 1, tp
= tbuf
; tp
< tend
; xp
++, id
++, fp
->ctf_typemax
++)
842 unsigned short kind
= LCTF_INFO_KIND (fp
, tp
->ctt_info
);
843 unsigned short isroot
= LCTF_INFO_ISROOT (fp
, tp
->ctt_info
);
844 unsigned long vlen
= LCTF_INFO_VLEN (fp
, tp
->ctt_info
);
845 ssize_t size
, increment
, vbytes
;
849 (void) ctf_get_ctt_size (fp
, tp
, &size
, &increment
);
850 name
= ctf_strptr (fp
, tp
->ctt_name
);
851 /* Cannot fail: shielded by call in loop above. */
852 vbytes
= LCTF_VBYTES (fp
, kind
, size
, vlen
);
854 *xp
= (uint32_t) ((uintptr_t) tp
- (uintptr_t) fp
->ctf_buf
);
863 ctf_encoding_t existing_en
;
864 ctf_encoding_t this_en
;
869 /* Names are reused by bitfields, which are differentiated by
870 their encodings. So check for the type already existing, and
871 iff the new type is a root-visible non-bitfield, replace the
872 old one. It's a little hard to figure out whether a type is
873 a non-bitfield without already knowing that type's native
874 width, but we can converge on it by replacing an existing
875 type as long as the new type is zero-offset and has a
876 bit-width wider than the existing one, since the native type
877 must necessarily have a bit-width at least as wide as any
878 bitfield based on it. */
880 if (((existing
= ctf_dynhash_lookup_type (fp
->ctf_names
, name
)) == 0)
881 || ctf_type_encoding (fp
, existing
, &existing_en
) != 0
882 || (ctf_type_encoding (fp
, LCTF_INDEX_TO_TYPE (fp
, id
, child
), &this_en
) == 0
883 && this_en
.cte_offset
== 0
884 && (existing_en
.cte_offset
!= 0
885 || existing_en
.cte_bits
< this_en
.cte_bits
)))
887 err
= ctf_dynhash_insert_type (fp
, fp
->ctf_names
,
888 LCTF_INDEX_TO_TYPE (fp
, id
, child
),
896 /* These kinds have no name, so do not need interning into any
906 err
= ctf_dynhash_insert_type (fp
, fp
->ctf_names
,
907 LCTF_INDEX_TO_TYPE (fp
, id
, child
),
914 if (size
>= CTF_LSTRUCT_THRESH
)
920 err
= ctf_dynhash_insert_type (fp
, fp
->ctf_structs
,
921 LCTF_INDEX_TO_TYPE (fp
, id
, child
),
930 if (size
>= CTF_LSTRUCT_THRESH
)
936 err
= ctf_dynhash_insert_type (fp
, fp
->ctf_unions
,
937 LCTF_INDEX_TO_TYPE (fp
, id
, child
),
949 err
= ctf_dynhash_insert_type (fp
, fp
->ctf_enums
,
950 LCTF_INDEX_TO_TYPE (fp
, id
, child
),
956 /* Remember all enums for later rescanning. */
958 err
= ctf_dynset_insert (all_enums
, (void *) (ptrdiff_t)
959 LCTF_INDEX_TO_TYPE (fp
, id
, child
));
969 err
= ctf_dynhash_insert_type (fp
, fp
->ctf_names
,
970 LCTF_INDEX_TO_TYPE (fp
, id
, child
),
978 ctf_dynhash_t
*h
= ctf_name_table (fp
, tp
->ctt_type
);
983 /* Only insert forward tags into the given hash if the type or tag
984 name is not already present. */
985 if (ctf_dynhash_lookup_type (h
, name
) == 0)
987 err
= ctf_dynhash_insert_type (fp
, h
, LCTF_INDEX_TO_TYPE (fp
, id
, child
),
996 /* If the type referenced by the pointer is in this CTF dict, then
997 store the index of the pointer type in fp->ctf_ptrtab[ index of
998 referenced type ]. */
1000 if (LCTF_TYPE_ISCHILD (fp
, tp
->ctt_type
) == child
1001 && LCTF_TYPE_TO_INDEX (fp
, tp
->ctt_type
) <= fp
->ctf_typemax
)
1002 fp
->ctf_ptrtab
[LCTF_TYPE_TO_INDEX (fp
, tp
->ctt_type
)] = id
;
1005 case CTF_K_VOLATILE
:
1007 case CTF_K_RESTRICT
:
1011 err
= ctf_dynhash_insert_type (fp
, fp
->ctf_names
,
1012 LCTF_INDEX_TO_TYPE (fp
, id
, child
),
1018 ctf_err_warn (fp
, 0, ECTF_CORRUPT
,
1019 _("init_static_types(): unhandled CTF kind: %x"), kind
);
1020 return ECTF_CORRUPT
;
1022 tp
= (ctf_type_t
*) ((uintptr_t) tp
+ increment
+ vbytes
);
1025 assert (fp
->ctf_typemax
== typemax
);
1027 ctf_dprintf ("%lu total types processed\n", fp
->ctf_typemax
);
1029 /* In the third pass, we traverse the enums we spotted earlier and track all
1030 the enumeration constants to aid in future detection of duplicates.
1032 Doing this in a third pass is necessary to avoid the case where an
1033 enum appears with a constant FOO, then later a type named FOO appears,
1034 too late to spot the conflict by checking the enum's constants. */
1036 while ((err
= ctf_dynset_next (all_enums
, &i
, &k
)) == 0)
1038 ctf_id_t enum_id
= (uintptr_t) k
;
1039 ctf_next_t
*i_constants
= NULL
;
1040 const char *cte_name
;
1042 while ((cte_name
= ctf_enum_next (fp
, enum_id
, &i_constants
, NULL
)) != NULL
)
1044 if (ctf_track_enumerator (fp
, enum_id
, cte_name
) < 0)
1046 ctf_next_destroy (i_constants
);
1047 ctf_next_destroy (i
);
1048 return ctf_errno (fp
);
1051 if (ctf_errno (fp
) != ECTF_NEXT_END
)
1053 ctf_next_destroy (i
);
1054 return ctf_errno (fp
);
1057 if (err
!= ECTF_NEXT_END
)
1060 ctf_dprintf ("%zu enum names hashed\n",
1061 ctf_dynhash_elements (fp
->ctf_enums
));
1062 ctf_dprintf ("%zu conflicting enumerators identified\n",
1063 ctf_dynset_elements (fp
->ctf_conflicting_enums
));
1064 ctf_dprintf ("%zu struct names hashed (%d long)\n",
1065 ctf_dynhash_elements (fp
->ctf_structs
), nlstructs
);
1066 ctf_dprintf ("%zu union names hashed (%d long)\n",
1067 ctf_dynhash_elements (fp
->ctf_unions
), nlunions
);
1068 ctf_dprintf ("%zu base type names and identifiers hashed\n",
1069 ctf_dynhash_elements (fp
->ctf_names
));
1074 /* Endianness-flipping routines.
1076 We flip everything, mindlessly, even 1-byte entities, so that future
1077 expansions do not require changes to this code. */
1079 /* Flip the endianness of the CTF header. */
1082 ctf_flip_header (ctf_header_t
*cth
)
1084 swap_thing (cth
->cth_preamble
.ctp_magic
);
1085 swap_thing (cth
->cth_preamble
.ctp_version
);
1086 swap_thing (cth
->cth_preamble
.ctp_flags
);
1087 swap_thing (cth
->cth_parlabel
);
1088 swap_thing (cth
->cth_parname
);
1089 swap_thing (cth
->cth_cuname
);
1090 swap_thing (cth
->cth_objtoff
);
1091 swap_thing (cth
->cth_funcoff
);
1092 swap_thing (cth
->cth_objtidxoff
);
1093 swap_thing (cth
->cth_funcidxoff
);
1094 swap_thing (cth
->cth_varoff
);
1095 swap_thing (cth
->cth_typeoff
);
1096 swap_thing (cth
->cth_stroff
);
1097 swap_thing (cth
->cth_strlen
);
1100 /* Flip the endianness of the label section, an array of ctf_lblent_t. */
1103 flip_lbls (void *start
, size_t len
)
1105 ctf_lblent_t
*lbl
= start
;
1108 for (i
= len
/ sizeof (struct ctf_lblent
); i
> 0; lbl
++, i
--)
1110 swap_thing (lbl
->ctl_label
);
1111 swap_thing (lbl
->ctl_type
);
1115 /* Flip the endianness of the data-object or function sections or their indexes,
1116 all arrays of uint32_t. */
1119 flip_objts (void *start
, size_t len
)
1121 uint32_t *obj
= start
;
1124 for (i
= len
/ sizeof (uint32_t); i
> 0; obj
++, i
--)
1128 /* Flip the endianness of the variable section, an array of ctf_varent_t. */
1131 flip_vars (void *start
, size_t len
)
1133 ctf_varent_t
*var
= start
;
1136 for (i
= len
/ sizeof (struct ctf_varent
); i
> 0; var
++, i
--)
1138 swap_thing (var
->ctv_name
);
1139 swap_thing (var
->ctv_type
);
1143 /* Flip the endianness of the type section, a tagged array of ctf_type or
1144 ctf_stype followed by variable data. */
1147 flip_types (ctf_dict_t
*fp
, void *start
, size_t len
, int to_foreign
)
1149 ctf_type_t
*t
= start
;
1151 while ((uintptr_t) t
< ((uintptr_t) start
) + len
)
1160 kind
= CTF_V2_INFO_KIND (t
->ctt_info
);
1162 vlen
= CTF_V2_INFO_VLEN (t
->ctt_info
);
1163 vbytes
= get_vbytes_v2 (fp
, kind
, size
, vlen
);
1166 swap_thing (t
->ctt_name
);
1167 swap_thing (t
->ctt_info
);
1168 swap_thing (t
->ctt_size
);
1172 kind
= CTF_V2_INFO_KIND (t
->ctt_info
);
1174 vlen
= CTF_V2_INFO_VLEN (t
->ctt_info
);
1175 vbytes
= get_vbytes_v2 (fp
, kind
, size
, vlen
);
1178 if (_libctf_unlikely_ (size
== CTF_LSIZE_SENT
))
1181 size
= CTF_TYPE_LSIZE (t
);
1183 swap_thing (t
->ctt_lsizehi
);
1184 swap_thing (t
->ctt_lsizelo
);
1187 size
= CTF_TYPE_LSIZE (t
);
1189 t
= (ctf_type_t
*) ((uintptr_t) t
+ sizeof (ctf_type_t
));
1192 t
= (ctf_type_t
*) ((uintptr_t) t
+ sizeof (ctf_stype_t
));
1200 case CTF_K_VOLATILE
:
1202 case CTF_K_RESTRICT
:
1203 /* These types have no vlen data to swap. */
1204 assert (vbytes
== 0);
1210 /* These types have a single uint32_t. */
1212 uint32_t *item
= (uint32_t *) t
;
1218 case CTF_K_FUNCTION
:
1220 /* This type has a bunch of uint32_ts. */
1222 uint32_t *item
= (uint32_t *) t
;
1225 for (i
= vlen
; i
> 0; item
++, i
--)
1232 /* This has a single ctf_array_t. */
1234 ctf_array_t
*a
= (ctf_array_t
*) t
;
1236 assert (vbytes
== sizeof (ctf_array_t
));
1237 swap_thing (a
->cta_contents
);
1238 swap_thing (a
->cta_index
);
1239 swap_thing (a
->cta_nelems
);
1246 /* This has a single ctf_slice_t. */
1248 ctf_slice_t
*s
= (ctf_slice_t
*) t
;
1250 assert (vbytes
== sizeof (ctf_slice_t
));
1251 swap_thing (s
->cts_type
);
1252 swap_thing (s
->cts_offset
);
1253 swap_thing (s
->cts_bits
);
1261 /* This has an array of ctf_member or ctf_lmember, depending on
1262 size. We could consider it to be a simple array of uint32_t,
1263 but for safety's sake in case these structures ever acquire
1264 non-uint32_t members, do it member by member. */
1266 if (_libctf_unlikely_ (size
>= CTF_LSTRUCT_THRESH
))
1268 ctf_lmember_t
*lm
= (ctf_lmember_t
*) t
;
1270 for (i
= vlen
; i
> 0; i
--, lm
++)
1272 swap_thing (lm
->ctlm_name
);
1273 swap_thing (lm
->ctlm_offsethi
);
1274 swap_thing (lm
->ctlm_type
);
1275 swap_thing (lm
->ctlm_offsetlo
);
1280 ctf_member_t
*m
= (ctf_member_t
*) t
;
1282 for (i
= vlen
; i
> 0; i
--, m
++)
1284 swap_thing (m
->ctm_name
);
1285 swap_thing (m
->ctm_offset
);
1286 swap_thing (m
->ctm_type
);
1294 /* This has an array of ctf_enum_t. */
1296 ctf_enum_t
*item
= (ctf_enum_t
*) t
;
1299 for (i
= vlen
; i
> 0; item
++, i
--)
1301 swap_thing (item
->cte_name
);
1302 swap_thing (item
->cte_value
);
1307 ctf_err_warn (fp
, 0, ECTF_CORRUPT
,
1308 _("unhandled CTF kind in endianness conversion: %x"),
1310 return ECTF_CORRUPT
;
1313 t
= (ctf_type_t
*) ((uintptr_t) t
+ vbytes
);
1319 /* Flip the endianness of BUF, given the offsets in the (native-endianness) CTH.
1320 If TO_FOREIGN is set, flip to foreign-endianness; if not, flip away.
1322 All of this stuff happens before the header is fully initialized, so the
1323 LCTF_*() macros cannot be used yet. Since we do not try to endian-convert v1
1324 data, this is no real loss. */
1327 ctf_flip (ctf_dict_t
*fp
, ctf_header_t
*cth
, unsigned char *buf
,
1330 ctf_dprintf("flipping endianness\n");
1332 flip_lbls (buf
+ cth
->cth_lbloff
, cth
->cth_objtoff
- cth
->cth_lbloff
);
1333 flip_objts (buf
+ cth
->cth_objtoff
, cth
->cth_funcoff
- cth
->cth_objtoff
);
1334 flip_objts (buf
+ cth
->cth_funcoff
, cth
->cth_objtidxoff
- cth
->cth_funcoff
);
1335 flip_objts (buf
+ cth
->cth_objtidxoff
, cth
->cth_funcidxoff
- cth
->cth_objtidxoff
);
1336 flip_objts (buf
+ cth
->cth_funcidxoff
, cth
->cth_varoff
- cth
->cth_funcidxoff
);
1337 flip_vars (buf
+ cth
->cth_varoff
, cth
->cth_typeoff
- cth
->cth_varoff
);
1338 return flip_types (fp
, buf
+ cth
->cth_typeoff
,
1339 cth
->cth_stroff
- cth
->cth_typeoff
, to_foreign
);
1342 /* Set up the ctl hashes in a ctf_dict_t. Called by both writable and
1343 non-writable dictionary initialization. */
1344 void ctf_set_ctl_hashes (ctf_dict_t
*fp
)
1346 /* Initialize the ctf_lookup_by_name top-level dictionary. We keep an
1347 array of type name prefixes and the corresponding ctf_hash to use. */
1348 fp
->ctf_lookups
[0].ctl_prefix
= "struct";
1349 fp
->ctf_lookups
[0].ctl_len
= strlen (fp
->ctf_lookups
[0].ctl_prefix
);
1350 fp
->ctf_lookups
[0].ctl_hash
= fp
->ctf_structs
;
1351 fp
->ctf_lookups
[1].ctl_prefix
= "union";
1352 fp
->ctf_lookups
[1].ctl_len
= strlen (fp
->ctf_lookups
[1].ctl_prefix
);
1353 fp
->ctf_lookups
[1].ctl_hash
= fp
->ctf_unions
;
1354 fp
->ctf_lookups
[2].ctl_prefix
= "enum";
1355 fp
->ctf_lookups
[2].ctl_len
= strlen (fp
->ctf_lookups
[2].ctl_prefix
);
1356 fp
->ctf_lookups
[2].ctl_hash
= fp
->ctf_enums
;
1357 fp
->ctf_lookups
[3].ctl_prefix
= _CTF_NULLSTR
;
1358 fp
->ctf_lookups
[3].ctl_len
= strlen (fp
->ctf_lookups
[3].ctl_prefix
);
1359 fp
->ctf_lookups
[3].ctl_hash
= fp
->ctf_names
;
1360 fp
->ctf_lookups
[4].ctl_prefix
= NULL
;
1361 fp
->ctf_lookups
[4].ctl_len
= 0;
1362 fp
->ctf_lookups
[4].ctl_hash
= NULL
;
1365 /* Open a CTF file, mocking up a suitable ctf_sect. */
1367 ctf_dict_t
*ctf_simple_open (const char *ctfsect
, size_t ctfsect_size
,
1368 const char *symsect
, size_t symsect_size
,
1369 size_t symsect_entsize
,
1370 const char *strsect
, size_t strsect_size
,
1373 ctf_sect_t skeleton
;
1375 ctf_sect_t ctf_sect
, sym_sect
, str_sect
;
1376 ctf_sect_t
*ctfsectp
= NULL
;
1377 ctf_sect_t
*symsectp
= NULL
;
1378 ctf_sect_t
*strsectp
= NULL
;
1380 skeleton
.cts_name
= _CTF_SECTION
;
1381 skeleton
.cts_entsize
= 1;
1385 memcpy (&ctf_sect
, &skeleton
, sizeof (struct ctf_sect
));
1386 ctf_sect
.cts_data
= ctfsect
;
1387 ctf_sect
.cts_size
= ctfsect_size
;
1388 ctfsectp
= &ctf_sect
;
1393 memcpy (&sym_sect
, &skeleton
, sizeof (struct ctf_sect
));
1394 sym_sect
.cts_data
= symsect
;
1395 sym_sect
.cts_size
= symsect_size
;
1396 sym_sect
.cts_entsize
= symsect_entsize
;
1397 symsectp
= &sym_sect
;
1402 memcpy (&str_sect
, &skeleton
, sizeof (struct ctf_sect
));
1403 str_sect
.cts_data
= strsect
;
1404 str_sect
.cts_size
= strsect_size
;
1405 strsectp
= &str_sect
;
1408 return ctf_bufopen (ctfsectp
, symsectp
, strsectp
, errp
);
1411 /* Decode the specified CTF buffer and optional symbol table, and create a new
1412 CTF dict representing the symbolic debugging information. This code can
1413 be used directly by the debugger, or it can be used as the engine for
1414 ctf_fdopen() or ctf_open(), below. */
1417 ctf_bufopen (const ctf_sect_t
*ctfsect
, const ctf_sect_t
*symsect
,
1418 const ctf_sect_t
*strsect
, int *errp
)
1420 const ctf_preamble_t
*pp
;
1421 size_t hdrsz
= sizeof (ctf_header_t
);
1424 int foreign_endian
= 0;
1427 libctf_init_debug();
1429 if ((ctfsect
== NULL
) || ((symsect
!= NULL
) && (strsect
== NULL
)))
1430 return (ctf_set_open_errno (errp
, EINVAL
));
1432 if (symsect
!= NULL
&& symsect
->cts_entsize
!= sizeof (Elf32_Sym
) &&
1433 symsect
->cts_entsize
!= sizeof (Elf64_Sym
))
1434 return (ctf_set_open_errno (errp
, ECTF_SYMTAB
));
1436 if (symsect
!= NULL
&& symsect
->cts_data
== NULL
)
1437 return (ctf_set_open_errno (errp
, ECTF_SYMBAD
));
1439 if (strsect
!= NULL
&& strsect
->cts_data
== NULL
)
1440 return (ctf_set_open_errno (errp
, ECTF_STRBAD
));
1442 if (ctfsect
->cts_data
== NULL
1443 || ctfsect
->cts_size
< sizeof (ctf_preamble_t
))
1444 return (ctf_set_open_errno (errp
, ECTF_NOCTFBUF
));
1446 pp
= (const ctf_preamble_t
*) ctfsect
->cts_data
;
1448 ctf_dprintf ("ctf_bufopen: magic=0x%x version=%u\n",
1449 pp
->ctp_magic
, pp
->ctp_version
);
1451 /* Validate each part of the CTF header.
1453 First, we validate the preamble (common to all versions). At that point,
1454 we know the endianness and specific header version, and can validate the
1455 version-specific parts including section offsets and alignments. */
1457 if (_libctf_unlikely_ (pp
->ctp_magic
!= CTF_MAGIC
))
1459 if (pp
->ctp_magic
== bswap_16 (CTF_MAGIC
))
1462 return (ctf_set_open_errno (errp
, ECTF_NOCTFBUF
));
1465 if (_libctf_unlikely_ ((pp
->ctp_version
< CTF_VERSION_1
)
1466 || (pp
->ctp_version
> CTF_VERSION_3
)))
1467 return (ctf_set_open_errno (errp
, ECTF_CTFVERS
));
1469 if ((symsect
!= NULL
) && (pp
->ctp_version
< CTF_VERSION_2
))
1471 /* The symtab can contain function entries which contain embedded ctf
1472 info. We do not support dynamically upgrading such entries (none
1473 should exist in any case, since dwarf2ctf does not create them). */
1475 ctf_err_warn (NULL
, 0, ECTF_NOTSUP
, _("ctf_bufopen: CTF version %d "
1476 "symsect not supported"),
1478 return (ctf_set_open_errno (errp
, ECTF_NOTSUP
));
1481 if (pp
->ctp_version
< CTF_VERSION_3
)
1482 hdrsz
= sizeof (ctf_header_v2_t
);
1484 if (_libctf_unlikely_ (pp
->ctp_flags
> CTF_F_MAX
))
1486 ctf_err_warn (NULL
, 0, ECTF_FLAGS
, _("ctf_bufopen: invalid header "
1488 (unsigned int) pp
->ctp_flags
);
1489 return (ctf_set_open_errno (errp
, ECTF_FLAGS
));
1492 if (ctfsect
->cts_size
< hdrsz
)
1493 return (ctf_set_open_errno (errp
, ECTF_NOCTFBUF
));
1495 if ((fp
= malloc (sizeof (ctf_dict_t
))) == NULL
)
1496 return (ctf_set_open_errno (errp
, ENOMEM
));
1498 memset (fp
, 0, sizeof (ctf_dict_t
));
1500 if ((fp
->ctf_header
= malloc (sizeof (struct ctf_header
))) == NULL
)
1503 return (ctf_set_open_errno (errp
, ENOMEM
));
1505 hp
= fp
->ctf_header
;
1506 memcpy (hp
, ctfsect
->cts_data
, hdrsz
);
1507 if (pp
->ctp_version
< CTF_VERSION_3
)
1508 upgrade_header (hp
);
1511 ctf_flip_header (hp
);
1512 fp
->ctf_openflags
= hp
->cth_flags
;
1513 fp
->ctf_size
= hp
->cth_stroff
+ hp
->cth_strlen
;
1515 ctf_dprintf ("ctf_bufopen: uncompressed size=%lu\n",
1516 (unsigned long) fp
->ctf_size
);
1518 if (hp
->cth_lbloff
> fp
->ctf_size
|| hp
->cth_objtoff
> fp
->ctf_size
1519 || hp
->cth_funcoff
> fp
->ctf_size
|| hp
->cth_objtidxoff
> fp
->ctf_size
1520 || hp
->cth_funcidxoff
> fp
->ctf_size
|| hp
->cth_typeoff
> fp
->ctf_size
1521 || hp
->cth_stroff
> fp
->ctf_size
)
1523 ctf_err_warn (NULL
, 0, ECTF_CORRUPT
, _("header offset exceeds CTF size"));
1524 return (ctf_set_open_errno (errp
, ECTF_CORRUPT
));
1527 if (hp
->cth_lbloff
> hp
->cth_objtoff
1528 || hp
->cth_objtoff
> hp
->cth_funcoff
1529 || hp
->cth_funcoff
> hp
->cth_typeoff
1530 || hp
->cth_funcoff
> hp
->cth_objtidxoff
1531 || hp
->cth_objtidxoff
> hp
->cth_funcidxoff
1532 || hp
->cth_funcidxoff
> hp
->cth_varoff
1533 || hp
->cth_varoff
> hp
->cth_typeoff
|| hp
->cth_typeoff
> hp
->cth_stroff
)
1535 ctf_err_warn (NULL
, 0, ECTF_CORRUPT
, _("overlapping CTF sections"));
1536 return (ctf_set_open_errno (errp
, ECTF_CORRUPT
));
1539 if ((hp
->cth_lbloff
& 3) || (hp
->cth_objtoff
& 2)
1540 || (hp
->cth_funcoff
& 2) || (hp
->cth_objtidxoff
& 2)
1541 || (hp
->cth_funcidxoff
& 2) || (hp
->cth_varoff
& 3)
1542 || (hp
->cth_typeoff
& 3))
1544 ctf_err_warn (NULL
, 0, ECTF_CORRUPT
,
1545 _("CTF sections not properly aligned"));
1546 return (ctf_set_open_errno (errp
, ECTF_CORRUPT
));
1549 /* This invariant will be lifted in v4, but for now it is true. */
1551 if ((hp
->cth_funcidxoff
- hp
->cth_objtidxoff
!= 0) &&
1552 (hp
->cth_funcidxoff
- hp
->cth_objtidxoff
1553 != hp
->cth_funcoff
- hp
->cth_objtoff
))
1555 ctf_err_warn (NULL
, 0, ECTF_CORRUPT
,
1556 _("Object index section is neither empty nor the "
1557 "same length as the object section: %u versus %u "
1558 "bytes"), hp
->cth_funcoff
- hp
->cth_objtoff
,
1559 hp
->cth_funcidxoff
- hp
->cth_objtidxoff
);
1560 return (ctf_set_open_errno (errp
, ECTF_CORRUPT
));
1563 if ((hp
->cth_varoff
- hp
->cth_funcidxoff
!= 0) &&
1564 (hp
->cth_varoff
- hp
->cth_funcidxoff
1565 != hp
->cth_objtidxoff
- hp
->cth_funcoff
) &&
1566 (hp
->cth_flags
& CTF_F_NEWFUNCINFO
))
1568 ctf_err_warn (NULL
, 0, ECTF_CORRUPT
,
1569 _("Function index section is neither empty nor the "
1570 "same length as the function section: %u versus %u "
1571 "bytes"), hp
->cth_objtidxoff
- hp
->cth_funcoff
,
1572 hp
->cth_varoff
- hp
->cth_funcidxoff
);
1573 return (ctf_set_open_errno (errp
, ECTF_CORRUPT
));
1576 /* Once everything is determined to be valid, attempt to decompress the CTF
1577 data buffer if it is compressed, or copy it into new storage if it is not
1578 compressed but needs endian-flipping. Otherwise we just put the data
1579 section's buffer pointer into ctf_buf, below. */
1581 /* Note: if this is a v1 buffer, it will be reallocated and expanded by
1582 init_static_types(). */
1584 if (hp
->cth_flags
& CTF_F_COMPRESS
)
1591 /* We are allocating this ourselves, so we can drop the ctf header
1592 copy in favour of ctf->ctf_header. */
1594 if ((fp
->ctf_base
= malloc (fp
->ctf_size
)) == NULL
)
1599 fp
->ctf_dynbase
= fp
->ctf_base
;
1600 hp
->cth_flags
&= ~CTF_F_COMPRESS
;
1602 src
= (unsigned char *) ctfsect
->cts_data
+ hdrsz
;
1603 srclen
= ctfsect
->cts_size
- hdrsz
;
1604 dstlen
= fp
->ctf_size
;
1605 fp
->ctf_buf
= fp
->ctf_base
;
1607 if ((rc
= uncompress (fp
->ctf_base
, &dstlen
, src
, srclen
)) != Z_OK
)
1609 ctf_err_warn (NULL
, 0, ECTF_DECOMPRESS
, _("zlib inflate err: %s"),
1611 err
= ECTF_DECOMPRESS
;
1615 if ((size_t) dstlen
!= fp
->ctf_size
)
1617 ctf_err_warn (NULL
, 0, ECTF_CORRUPT
,
1618 _("zlib inflate short: got %lu of %lu bytes"),
1619 (unsigned long) dstlen
, (unsigned long) fp
->ctf_size
);
1626 if (_libctf_unlikely_ (ctfsect
->cts_size
< hdrsz
+ fp
->ctf_size
))
1628 ctf_err_warn (NULL
, 0, ECTF_CORRUPT
,
1629 _("%lu byte long CTF dictionary overruns %lu byte long CTF section"),
1630 (unsigned long) ctfsect
->cts_size
,
1631 (unsigned long) (hdrsz
+ fp
->ctf_size
));
1638 if ((fp
->ctf_base
= malloc (fp
->ctf_size
)) == NULL
)
1643 fp
->ctf_dynbase
= fp
->ctf_base
;
1644 memcpy (fp
->ctf_base
, ((unsigned char *) ctfsect
->cts_data
) + hdrsz
,
1646 fp
->ctf_buf
= fp
->ctf_base
;
1650 /* We are just using the section passed in -- but its header may
1651 be an old version. Point ctf_buf past the old header, and
1652 never touch it again. */
1653 fp
->ctf_base
= (unsigned char *) ctfsect
->cts_data
;
1654 fp
->ctf_dynbase
= NULL
;
1655 fp
->ctf_buf
= fp
->ctf_base
+ hdrsz
;
1659 /* Once we have uncompressed and validated the CTF data buffer, we can
1660 proceed with initializing the ctf_dict_t we allocated above.
1662 Nothing that depends on buf or base should be set directly in this function
1663 before the init_static_types() call, because it may be reallocated during
1664 transparent upgrade if this recension of libctf is so configured: see
1667 ctf_set_version (fp
, hp
, hp
->cth_version
);
1669 /* Temporary assignment, just enough to be able to initialize
1672 fp
->ctf_str
[CTF_STRTAB_0
].cts_strs
= (const char *) fp
->ctf_buf
1674 fp
->ctf_str
[CTF_STRTAB_0
].cts_len
= hp
->cth_strlen
;
1675 if (ctf_str_create_atoms (fp
) < 0)
1681 fp
->ctf_parmax
= CTF_MAX_PTYPE
;
1682 memcpy (&fp
->ctf_data
, ctfsect
, sizeof (ctf_sect_t
));
1684 if (symsect
!= NULL
)
1686 memcpy (&fp
->ctf_ext_symtab
, symsect
, sizeof (ctf_sect_t
));
1687 memcpy (&fp
->ctf_ext_strtab
, strsect
, sizeof (ctf_sect_t
));
1690 if (fp
->ctf_data
.cts_name
!= NULL
)
1691 if ((fp
->ctf_data
.cts_name
= strdup (fp
->ctf_data
.cts_name
)) == NULL
)
1696 if (fp
->ctf_ext_symtab
.cts_name
!= NULL
)
1697 if ((fp
->ctf_ext_symtab
.cts_name
= strdup (fp
->ctf_ext_symtab
.cts_name
)) == NULL
)
1702 if (fp
->ctf_ext_strtab
.cts_name
!= NULL
)
1703 if ((fp
->ctf_ext_strtab
.cts_name
= strdup (fp
->ctf_ext_strtab
.cts_name
)) == NULL
)
1709 if (fp
->ctf_data
.cts_name
== NULL
)
1710 fp
->ctf_data
.cts_name
= _CTF_NULLSTR
;
1711 if (fp
->ctf_ext_symtab
.cts_name
== NULL
)
1712 fp
->ctf_ext_symtab
.cts_name
= _CTF_NULLSTR
;
1713 if (fp
->ctf_ext_strtab
.cts_name
== NULL
)
1714 fp
->ctf_ext_strtab
.cts_name
= _CTF_NULLSTR
;
1716 if (strsect
!= NULL
)
1718 fp
->ctf_str
[CTF_STRTAB_1
].cts_strs
= strsect
->cts_data
;
1719 fp
->ctf_str
[CTF_STRTAB_1
].cts_len
= strsect
->cts_size
;
1722 /* Dynamic state, for dynamic addition to this dict after loading. */
1724 fp
->ctf_dthash
= ctf_dynhash_create (ctf_hash_integer
, ctf_hash_eq_integer
,
1726 fp
->ctf_dvhash
= ctf_dynhash_create (ctf_hash_string
, ctf_hash_eq_string
,
1728 fp
->ctf_snapshots
= 1;
1730 fp
->ctf_objthash
= ctf_dynhash_create (ctf_hash_string
, ctf_hash_eq_string
,
1732 fp
->ctf_funchash
= ctf_dynhash_create (ctf_hash_string
, ctf_hash_eq_string
,
1735 if (!fp
->ctf_dthash
|| !fp
->ctf_dvhash
|| !fp
->ctf_snapshots
||
1736 !fp
->ctf_objthash
|| !fp
->ctf_funchash
)
1742 if (foreign_endian
&&
1743 (err
= ctf_flip (fp
, hp
, fp
->ctf_buf
, 0)) != 0)
1745 /* We can be certain that ctf_flip() will have endian-flipped everything
1746 other than the types table when we return. In particular the header
1747 is fine, so set it, to allow freeing to use the usual code path. */
1749 ctf_set_base (fp
, hp
, fp
->ctf_base
);
1753 ctf_set_base (fp
, hp
, fp
->ctf_base
);
1755 if ((err
= init_static_types (fp
, hp
)) != 0)
1758 /* Allocate and initialize the symtab translation table, pointed to by
1759 ctf_sxlate, and the corresponding index sections. This table may be too
1760 large for the actual size of the object and function info sections: if so,
1761 ctf_nsyms will be adjusted and the excess will never be used. It's
1762 possible to do indexed symbol lookups even without a symbol table, so check
1763 even in that case. Initially, we assume the symtab is native-endian: if it
1764 isn't, the caller will inform us later by calling ctf_symsect_endianness. */
1765 #ifdef WORDS_BIGENDIAN
1766 fp
->ctf_symsect_little_endian
= 0;
1768 fp
->ctf_symsect_little_endian
= 1;
1771 if (symsect
!= NULL
)
1773 fp
->ctf_nsyms
= symsect
->cts_size
/ symsect
->cts_entsize
;
1774 fp
->ctf_sxlate
= malloc (fp
->ctf_nsyms
* sizeof (uint32_t));
1776 if (fp
->ctf_sxlate
== NULL
)
1783 if ((err
= init_symtab (fp
, hp
, symsect
)) != 0)
1786 ctf_set_ctl_hashes (fp
);
1788 if (symsect
!= NULL
)
1790 if (symsect
->cts_entsize
== sizeof (Elf64_Sym
))
1791 (void) ctf_setmodel (fp
, CTF_MODEL_LP64
);
1793 (void) ctf_setmodel (fp
, CTF_MODEL_ILP32
);
1796 (void) ctf_setmodel (fp
, CTF_MODEL_NATIVE
);
1802 ctf_set_open_errno (errp
, err
);
1803 ctf_err_warn_to_open (fp
);
1804 /* Without this, the refcnt is zero on entry and ctf_dict_close() won't
1805 actually do anything on the grounds that this is a recursive call via
1806 another dict being closed. */
1808 ctf_dict_close (fp
);
1812 /* Bump the refcount on the specified CTF dict, to allow export of ctf_dict_t's
1813 from iterators that open and close the ctf_dict_t around the loop. (This
1814 does not extend their lifetime beyond that of the ctf_archive_t in which they
1818 ctf_ref (ctf_dict_t
*fp
)
1823 /* Close the specified CTF dict and free associated data structures. Note that
1824 ctf_dict_close() is a reference counted operation: if the specified file is
1825 the parent of other active dict, its reference count will be greater than one
1826 and it will be freed later when no active children exist. */
1829 ctf_dict_close (ctf_dict_t
*fp
)
1831 ctf_dtdef_t
*dtd
, *ntd
;
1832 ctf_dvdef_t
*dvd
, *nvd
;
1833 ctf_in_flight_dynsym_t
*did
, *nid
;
1834 ctf_err_warning_t
*err
, *nerr
;
1837 return; /* Allow ctf_dict_close(NULL) to simplify caller code. */
1839 ctf_dprintf ("ctf_dict_close(%p) refcnt=%u\n", (void *) fp
, fp
->ctf_refcnt
);
1841 if (fp
->ctf_refcnt
> 1)
1847 /* It is possible to recurse back in here, notably if dicts in the
1848 ctf_link_inputs or ctf_link_outputs cite this dict as a parent without
1849 using ctf_import_unref. Do nothing in that case. */
1850 if (fp
->ctf_refcnt
== 0)
1854 free (fp
->ctf_dyncuname
);
1855 free (fp
->ctf_dynparname
);
1856 if (fp
->ctf_parent
&& !fp
->ctf_parent_unreffed
)
1857 ctf_dict_close (fp
->ctf_parent
);
1859 for (dtd
= ctf_list_next (&fp
->ctf_dtdefs
); dtd
!= NULL
; dtd
= ntd
)
1861 ntd
= ctf_list_next (dtd
);
1862 ctf_dtd_delete (fp
, dtd
);
1864 ctf_dynhash_destroy (fp
->ctf_dthash
);
1866 ctf_dynset_destroy (fp
->ctf_conflicting_enums
);
1867 ctf_dynhash_destroy (fp
->ctf_structs
);
1868 ctf_dynhash_destroy (fp
->ctf_unions
);
1869 ctf_dynhash_destroy (fp
->ctf_enums
);
1870 ctf_dynhash_destroy (fp
->ctf_names
);
1872 for (dvd
= ctf_list_next (&fp
->ctf_dvdefs
); dvd
!= NULL
; dvd
= nvd
)
1874 nvd
= ctf_list_next (dvd
);
1875 ctf_dvd_delete (fp
, dvd
);
1877 ctf_dynhash_destroy (fp
->ctf_dvhash
);
1879 ctf_dynhash_destroy (fp
->ctf_symhash_func
);
1880 ctf_dynhash_destroy (fp
->ctf_symhash_objt
);
1881 free (fp
->ctf_funcidx_sxlate
);
1882 free (fp
->ctf_objtidx_sxlate
);
1883 ctf_dynhash_destroy (fp
->ctf_objthash
);
1884 ctf_dynhash_destroy (fp
->ctf_funchash
);
1885 free (fp
->ctf_dynsymidx
);
1886 ctf_dynhash_destroy (fp
->ctf_dynsyms
);
1887 for (did
= ctf_list_next (&fp
->ctf_in_flight_dynsyms
); did
!= NULL
; did
= nid
)
1889 nid
= ctf_list_next (did
);
1890 ctf_list_delete (&fp
->ctf_in_flight_dynsyms
, did
);
1894 ctf_str_free_atoms (fp
);
1895 free (fp
->ctf_tmp_typeslice
);
1897 if (fp
->ctf_data
.cts_name
!= _CTF_NULLSTR
)
1898 free ((char *) fp
->ctf_data
.cts_name
);
1900 if (fp
->ctf_ext_symtab
.cts_name
!= _CTF_NULLSTR
)
1901 free ((char *) fp
->ctf_ext_symtab
.cts_name
);
1903 if (fp
->ctf_ext_strtab
.cts_name
!= _CTF_NULLSTR
)
1904 free ((char *) fp
->ctf_ext_strtab
.cts_name
);
1905 else if (fp
->ctf_data_mmapped
)
1906 ctf_munmap (fp
->ctf_data_mmapped
, fp
->ctf_data_mmapped_len
);
1908 free (fp
->ctf_dynbase
);
1910 ctf_dynhash_destroy (fp
->ctf_syn_ext_strtab
);
1911 ctf_dynhash_destroy (fp
->ctf_link_inputs
);
1912 ctf_dynhash_destroy (fp
->ctf_link_outputs
);
1913 ctf_dynhash_destroy (fp
->ctf_link_type_mapping
);
1914 ctf_dynhash_destroy (fp
->ctf_link_in_cu_mapping
);
1915 ctf_dynhash_destroy (fp
->ctf_link_out_cu_mapping
);
1916 ctf_dynhash_destroy (fp
->ctf_add_processing
);
1917 ctf_dedup_fini (fp
, NULL
, 0);
1918 ctf_dynset_destroy (fp
->ctf_dedup_atoms_alloc
);
1920 for (err
= ctf_list_next (&fp
->ctf_errs_warnings
); err
!= NULL
; err
= nerr
)
1922 nerr
= ctf_list_next (err
);
1923 ctf_list_delete (&fp
->ctf_errs_warnings
, err
);
1924 free (err
->cew_text
);
1928 free (fp
->ctf_sxlate
);
1929 free (fp
->ctf_txlate
);
1930 free (fp
->ctf_ptrtab
);
1931 free (fp
->ctf_pptrtab
);
1933 free (fp
->ctf_header
);
1937 /* Backward compatibility. */
1939 ctf_file_close (ctf_file_t
*fp
)
1941 ctf_dict_close (fp
);
1944 /* The converse of ctf_open(). ctf_open() disguises whatever it opens as an
1945 archive, so closing one is just like closing an archive. */
1947 ctf_close (ctf_archive_t
*arc
)
1949 ctf_arc_close (arc
);
1952 /* Get the CTF archive from which this ctf_dict_t is derived. */
1954 ctf_get_arc (const ctf_dict_t
*fp
)
1956 return fp
->ctf_archive
;
1959 /* Return the ctfsect out of the core ctf_impl. Useful for freeing the
1960 ctfsect's data * after ctf_dict_close(), which is why we return the actual
1961 structure, not a pointer to it, since that is likely to become a pointer to
1962 freed data before the return value is used under the expected use case of
1963 ctf_getsect()/ ctf_dict_close()/free(). */
1965 ctf_getdatasect (const ctf_dict_t
*fp
)
1967 return fp
->ctf_data
;
1971 ctf_getsymsect (const ctf_dict_t
*fp
)
1973 return fp
->ctf_ext_symtab
;
1977 ctf_getstrsect (const ctf_dict_t
*fp
)
1979 return fp
->ctf_ext_strtab
;
1982 /* Set the endianness of the symbol table attached to FP. */
1984 ctf_symsect_endianness (ctf_dict_t
*fp
, int little_endian
)
1986 int old_endianness
= fp
->ctf_symsect_little_endian
;
1988 fp
->ctf_symsect_little_endian
= !!little_endian
;
1990 /* If we already have a symtab translation table, we need to repopulate it if
1991 our idea of the endianness has changed. */
1993 if (old_endianness
!= fp
->ctf_symsect_little_endian
1994 && fp
->ctf_sxlate
!= NULL
&& fp
->ctf_ext_symtab
.cts_data
!= NULL
)
1995 assert (init_symtab (fp
, fp
->ctf_header
, &fp
->ctf_ext_symtab
) == 0);
1998 /* Return the CTF handle for the parent CTF dict, if one exists. Otherwise
1999 return NULL to indicate this dict has no imported parent. */
2001 ctf_parent_dict (ctf_dict_t
*fp
)
2003 return fp
->ctf_parent
;
2006 /* Backward compatibility. */
2008 ctf_parent_file (ctf_dict_t
*fp
)
2010 return ctf_parent_dict (fp
);
2013 /* Return the name of the parent CTF dict, if one exists, or NULL otherwise. */
2015 ctf_parent_name (ctf_dict_t
*fp
)
2017 return fp
->ctf_parname
;
2020 /* Set the parent name. It is an error to call this routine without calling
2021 ctf_import() at some point. */
2023 ctf_parent_name_set (ctf_dict_t
*fp
, const char *name
)
2025 if (fp
->ctf_dynparname
!= NULL
)
2026 free (fp
->ctf_dynparname
);
2028 if ((fp
->ctf_dynparname
= strdup (name
)) == NULL
)
2029 return (ctf_set_errno (fp
, ENOMEM
));
2030 fp
->ctf_parname
= fp
->ctf_dynparname
;
2034 /* Return the name of the compilation unit this CTF file applies to. Usually
2035 non-NULL only for non-parent dicts. */
2037 ctf_cuname (ctf_dict_t
*fp
)
2039 return fp
->ctf_cuname
;
2042 /* Set the compilation unit name. */
2044 ctf_cuname_set (ctf_dict_t
*fp
, const char *name
)
2046 if (fp
->ctf_dyncuname
!= NULL
)
2047 free (fp
->ctf_dyncuname
);
2049 if ((fp
->ctf_dyncuname
= strdup (name
)) == NULL
)
2050 return (ctf_set_errno (fp
, ENOMEM
));
2051 fp
->ctf_cuname
= fp
->ctf_dyncuname
;
2055 /* Import the types from the specified parent dict by storing a pointer to it in
2056 ctf_parent and incrementing its reference count. Only one parent is allowed:
2057 if a parent already exists, it is replaced by the new parent. The pptrtab
2058 is wiped, and will be refreshed by the next ctf_lookup_by_name call. */
2060 ctf_import (ctf_dict_t
*fp
, ctf_dict_t
*pfp
)
2062 if (fp
== NULL
|| fp
== pfp
|| (pfp
!= NULL
&& pfp
->ctf_refcnt
== 0))
2063 return (ctf_set_errno (fp
, EINVAL
));
2065 if (pfp
!= NULL
&& pfp
->ctf_dmodel
!= fp
->ctf_dmodel
)
2066 return (ctf_set_errno (fp
, ECTF_DMODEL
));
2068 if (fp
->ctf_parent
&& !fp
->ctf_parent_unreffed
)
2069 ctf_dict_close (fp
->ctf_parent
);
2070 fp
->ctf_parent
= NULL
;
2072 free (fp
->ctf_pptrtab
);
2073 fp
->ctf_pptrtab
= NULL
;
2074 fp
->ctf_pptrtab_len
= 0;
2075 fp
->ctf_pptrtab_typemax
= 0;
2081 if (fp
->ctf_parname
== NULL
)
2082 if ((err
= ctf_parent_name_set (fp
, "PARENT")) < 0)
2085 fp
->ctf_flags
|= LCTF_CHILD
;
2087 fp
->ctf_parent_unreffed
= 0;
2090 fp
->ctf_parent
= pfp
;
2094 /* Like ctf_import, but does not increment the refcount on the imported parent
2095 or close it at any point: as a result it can go away at any time and the
2096 caller must do all freeing itself. Used internally to avoid refcount
2099 ctf_import_unref (ctf_dict_t
*fp
, ctf_dict_t
*pfp
)
2101 if (fp
== NULL
|| fp
== pfp
|| (pfp
!= NULL
&& pfp
->ctf_refcnt
== 0))
2102 return (ctf_set_errno (fp
, EINVAL
));
2104 if (pfp
!= NULL
&& pfp
->ctf_dmodel
!= fp
->ctf_dmodel
)
2105 return (ctf_set_errno (fp
, ECTF_DMODEL
));
2107 if (fp
->ctf_parent
&& !fp
->ctf_parent_unreffed
)
2108 ctf_dict_close (fp
->ctf_parent
);
2109 fp
->ctf_parent
= NULL
;
2111 free (fp
->ctf_pptrtab
);
2112 fp
->ctf_pptrtab
= NULL
;
2113 fp
->ctf_pptrtab_len
= 0;
2114 fp
->ctf_pptrtab_typemax
= 0;
2119 if (fp
->ctf_parname
== NULL
)
2120 if ((err
= ctf_parent_name_set (fp
, "PARENT")) < 0)
2123 fp
->ctf_flags
|= LCTF_CHILD
;
2124 fp
->ctf_parent_unreffed
= 1;
2127 fp
->ctf_parent
= pfp
;
2131 /* Set the data model constant for the CTF dict. */
2133 ctf_setmodel (ctf_dict_t
*fp
, int model
)
2135 const ctf_dmodel_t
*dp
;
2137 for (dp
= _libctf_models
; dp
->ctd_name
!= NULL
; dp
++)
2139 if (dp
->ctd_code
== model
)
2141 fp
->ctf_dmodel
= dp
;
2146 return (ctf_set_errno (fp
, EINVAL
));
2149 /* Return the data model constant for the CTF dict. */
2151 ctf_getmodel (ctf_dict_t
*fp
)
2153 return fp
->ctf_dmodel
->ctd_code
;
2156 /* The caller can hang an arbitrary pointer off each ctf_dict_t using this
2159 ctf_setspecific (ctf_dict_t
*fp
, void *data
)
2161 fp
->ctf_specific
= data
;
2164 /* Retrieve the arbitrary pointer again. */
2166 ctf_getspecific (ctf_dict_t
*fp
)
2168 return fp
->ctf_specific
;