10Sstevel@tonic-gate /* 20Sstevel@tonic-gate * CDDL HEADER START 30Sstevel@tonic-gate * 40Sstevel@tonic-gate * The contents of this file are subject to the terms of the 51682Srie * Common Development and Distribution License (the "License"). 61682Srie * You may not use this file except in compliance with the License. 70Sstevel@tonic-gate * 80Sstevel@tonic-gate * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 90Sstevel@tonic-gate * or http://www.opensolaris.org/os/licensing. 100Sstevel@tonic-gate * See the License for the specific language governing permissions 110Sstevel@tonic-gate * and limitations under the License. 120Sstevel@tonic-gate * 130Sstevel@tonic-gate * When distributing Covered Code, include this CDDL HEADER in each 140Sstevel@tonic-gate * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 150Sstevel@tonic-gate * If applicable, add the following below this CDDL HEADER, with the 160Sstevel@tonic-gate * fields enclosed by brackets "[]" replaced with your own identifying 170Sstevel@tonic-gate * information: Portions Copyright [yyyy] [name of copyright owner] 180Sstevel@tonic-gate * 190Sstevel@tonic-gate * CDDL HEADER END 200Sstevel@tonic-gate */ 210Sstevel@tonic-gate 220Sstevel@tonic-gate /* 231682Srie * Copyright (c) 1988 AT&T 241682Srie * All Rights Reserved 251682Srie * 2612449SRod.Evans@Sun.COM * Copyright (c) 1989, 2010, Oracle and/or its affiliates. All rights reserved. 270Sstevel@tonic-gate */ 280Sstevel@tonic-gate 290Sstevel@tonic-gate #ifndef _SYS_LINK_H 300Sstevel@tonic-gate #define _SYS_LINK_H 310Sstevel@tonic-gate 320Sstevel@tonic-gate #ifndef _ASM 330Sstevel@tonic-gate #include <sys/types.h> 340Sstevel@tonic-gate #include <sys/elftypes.h> 350Sstevel@tonic-gate #endif 360Sstevel@tonic-gate 370Sstevel@tonic-gate #ifdef __cplusplus 380Sstevel@tonic-gate extern "C" { 390Sstevel@tonic-gate #endif 400Sstevel@tonic-gate 410Sstevel@tonic-gate /* 420Sstevel@tonic-gate * Communication structures for the runtime linker. 430Sstevel@tonic-gate */ 440Sstevel@tonic-gate 450Sstevel@tonic-gate /* 460Sstevel@tonic-gate * The following data structure provides a self-identifying union consisting 470Sstevel@tonic-gate * of a tag from a known list and a value. 480Sstevel@tonic-gate */ 490Sstevel@tonic-gate #ifndef _ASM 500Sstevel@tonic-gate typedef struct { 510Sstevel@tonic-gate Elf32_Sword d_tag; /* how to interpret value */ 520Sstevel@tonic-gate union { 530Sstevel@tonic-gate Elf32_Word d_val; 540Sstevel@tonic-gate Elf32_Addr d_ptr; 550Sstevel@tonic-gate Elf32_Off d_off; 560Sstevel@tonic-gate } d_un; 570Sstevel@tonic-gate } Elf32_Dyn; 580Sstevel@tonic-gate 590Sstevel@tonic-gate #if defined(_LP64) || defined(_LONGLONG_TYPE) 600Sstevel@tonic-gate typedef struct { 610Sstevel@tonic-gate Elf64_Xword d_tag; /* how to interpret value */ 620Sstevel@tonic-gate union { 630Sstevel@tonic-gate Elf64_Xword d_val; 640Sstevel@tonic-gate Elf64_Addr d_ptr; 650Sstevel@tonic-gate } d_un; 660Sstevel@tonic-gate } Elf64_Dyn; 670Sstevel@tonic-gate #endif /* defined(_LP64) || defined(_LONGLONG_TYPE) */ 680Sstevel@tonic-gate #endif /* _ASM */ 690Sstevel@tonic-gate 700Sstevel@tonic-gate /* 710Sstevel@tonic-gate * Tag values 720Sstevel@tonic-gate */ 730Sstevel@tonic-gate #define DT_NULL 0 /* last entry in list */ 740Sstevel@tonic-gate #define DT_NEEDED 1 /* a needed object */ 750Sstevel@tonic-gate #define DT_PLTRELSZ 2 /* size of relocations for the PLT */ 760Sstevel@tonic-gate #define DT_PLTGOT 3 /* addresses used by procedure linkage table */ 770Sstevel@tonic-gate #define DT_HASH 4 /* hash table */ 780Sstevel@tonic-gate #define DT_STRTAB 5 /* string table */ 790Sstevel@tonic-gate #define DT_SYMTAB 6 /* symbol table */ 800Sstevel@tonic-gate #define DT_RELA 7 /* addr of relocation entries */ 810Sstevel@tonic-gate #define DT_RELASZ 8 /* size of relocation table */ 820Sstevel@tonic-gate #define DT_RELAENT 9 /* base size of relocation entry */ 830Sstevel@tonic-gate #define DT_STRSZ 10 /* size of string table */ 840Sstevel@tonic-gate #define DT_SYMENT 11 /* size of symbol table entry */ 850Sstevel@tonic-gate #define DT_INIT 12 /* _init addr */ 860Sstevel@tonic-gate #define DT_FINI 13 /* _fini addr */ 870Sstevel@tonic-gate #define DT_SONAME 14 /* name of this shared object */ 880Sstevel@tonic-gate #define DT_RPATH 15 /* run-time search path */ 890Sstevel@tonic-gate #define DT_SYMBOLIC 16 /* shared object linked -Bsymbolic */ 900Sstevel@tonic-gate #define DT_REL 17 /* addr of relocation entries */ 910Sstevel@tonic-gate #define DT_RELSZ 18 /* size of relocation table */ 920Sstevel@tonic-gate #define DT_RELENT 19 /* base size of relocation entry */ 930Sstevel@tonic-gate #define DT_PLTREL 20 /* relocation type for PLT entry */ 940Sstevel@tonic-gate #define DT_DEBUG 21 /* pointer to r_debug structure */ 950Sstevel@tonic-gate #define DT_TEXTREL 22 /* text relocations remain for this object */ 960Sstevel@tonic-gate #define DT_JMPREL 23 /* pointer to the PLT relocation entries */ 970Sstevel@tonic-gate #define DT_BIND_NOW 24 /* perform all relocations at load of object */ 9812736SAli.Bahrami@Oracle.COM #define DT_INIT_ARRAY 25 /* pointer to .init_array */ 9912736SAli.Bahrami@Oracle.COM #define DT_FINI_ARRAY 26 /* pointer to .fini_array */ 10012736SAli.Bahrami@Oracle.COM #define DT_INIT_ARRAYSZ 27 /* size of .init_array */ 10112736SAli.Bahrami@Oracle.COM #define DT_FINI_ARRAYSZ 28 /* size of .fini_array */ 1020Sstevel@tonic-gate #define DT_RUNPATH 29 /* run-time search path */ 1030Sstevel@tonic-gate #define DT_FLAGS 30 /* state flags - see DF_* */ 1040Sstevel@tonic-gate 1053492Sab196087 /* 1063492Sab196087 * DT_* encoding rules: The value of each dynamic tag determines the 1073492Sab196087 * interpretation of the d_un union. This convention provides for simpler 1083492Sab196087 * interpretation of dynamic tags by external tools. A tag whose value 1093492Sab196087 * is an even number indicates a dynamic section entry that uses d_ptr. 1103492Sab196087 * A tag whose value is an odd number indicates a dynamic section entry 1113492Sab196087 * that uses d_val, or that uses neither d_ptr nor d_val. 1123492Sab196087 * 1133492Sab196087 * There are exceptions to the above rule: 1143492Sab196087 * - Tags with values that are less than DT_ENCODING. 1153492Sab196087 * - Tags with values that fall between DT_LOOS and DT_SUNW_ENCODING 1163492Sab196087 * - Tags with values that fall between DT_HIOS and DT_LOPROC 1173492Sab196087 * 1183492Sab196087 * Third party tools must handle these exception ranges explicitly 1193492Sab196087 * on an item by item basis. 1203492Sab196087 */ 1213492Sab196087 #define DT_ENCODING 32 /* positive tag DT_* encoding rules */ 1223492Sab196087 /* start after this */ 12312736SAli.Bahrami@Oracle.COM #define DT_PREINIT_ARRAY 32 /* pointer to .preinit_array */ 12412736SAli.Bahrami@Oracle.COM #define DT_PREINIT_ARRAYSZ 33 /* size of .preinit_array */ 1250Sstevel@tonic-gate 1260Sstevel@tonic-gate #define DT_MAXPOSTAGS 34 /* number of positive tags */ 1270Sstevel@tonic-gate 1283492Sab196087 /* 1293492Sab196087 * DT_* encoding rules do not apply between DT_LOOS and DT_SUNW_ENCODING 1303492Sab196087 */ 1310Sstevel@tonic-gate #define DT_LOOS 0x6000000d /* OS specific range */ 1320Sstevel@tonic-gate #define DT_SUNW_AUXILIARY 0x6000000d /* symbol auxiliary name */ 1330Sstevel@tonic-gate #define DT_SUNW_RTLDINF 0x6000000e /* ld.so.1 info (private) */ 1340Sstevel@tonic-gate #define DT_SUNW_FILTER 0x6000000f /* symbol filter name */ 1350Sstevel@tonic-gate #define DT_SUNW_CAP 0x60000010 /* hardware/software */ 1360Sstevel@tonic-gate /* capabilities */ 1372766Sab196087 #define DT_SUNW_SYMTAB 0x60000011 /* symtab with local fcn */ 1382766Sab196087 /* symbols immediately */ 1392766Sab196087 /* preceding DT_SYMTAB */ 1403492Sab196087 #define DT_SUNW_SYMSZ 0x60000012 /* Size of SUNW_SYMTAB table */ 1413492Sab196087 1423492Sab196087 /* 1433492Sab196087 * DT_* encoding rules apply between DT_SUNW_ENCODING and DT_HIOS 1443492Sab196087 */ 1453492Sab196087 #define DT_SUNW_ENCODING 0x60000013 /* DT_* encoding rules resume */ 1463492Sab196087 /* after this */ 1479273SAli.Bahrami@Sun.COM #define DT_SUNW_SORTENT 0x60000013 /* sizeof [SYM|TLS]SORT entry */ 1483492Sab196087 #define DT_SUNW_SYMSORT 0x60000014 /* sym indices sorted by addr */ 1493492Sab196087 #define DT_SUNW_SYMSORTSZ 0x60000015 /* size of SUNW_SYMSORT */ 1503492Sab196087 #define DT_SUNW_TLSSORT 0x60000016 /* tls sym ndx sort by offset */ 1513492Sab196087 #define DT_SUNW_TLSSORTSZ 0x60000017 /* size of SUNW_TLSSORT */ 15211827SRod.Evans@Sun.COM #define DT_SUNW_CAPINFO 0x60000018 /* capabilities symbols */ 1533850Sab196087 #define DT_SUNW_STRPAD 0x60000019 /* # of unused bytes at the */ 1543850Sab196087 /* end of dynstr */ 15511827SRod.Evans@Sun.COM #define DT_SUNW_CAPCHAIN 0x6000001a /* capabilities chain info */ 1566206Sab196087 #define DT_SUNW_LDMACH 0x6000001b /* EM_ machine code of linker */ 1576206Sab196087 /* that produced object */ 15811827SRod.Evans@Sun.COM #define DT_SUNW_CAPCHAINENT 0x6000001d /* capabilities chain entry */ 15911827SRod.Evans@Sun.COM #define DT_SUNW_CAPCHAINSZ 0x6000001f /* capabilities chain size */ 1603850Sab196087 1613492Sab196087 /* 1623492Sab196087 * DT_* encoding rules do not apply between DT_HIOS and DT_LOPROC 1633492Sab196087 */ 1640Sstevel@tonic-gate #define DT_HIOS 0x6ffff000 1650Sstevel@tonic-gate 1660Sstevel@tonic-gate /* 1670Sstevel@tonic-gate * The following values have been deprecated and remain here to allow 1680Sstevel@tonic-gate * compatibility with older binaries. 1690Sstevel@tonic-gate */ 1700Sstevel@tonic-gate #define DT_DEPRECATED_SPARC_REGISTER 0x7000001 1710Sstevel@tonic-gate 1720Sstevel@tonic-gate /* 1730Sstevel@tonic-gate * DT_* entries which fall between DT_VALRNGHI & DT_VALRNGLO use the 1740Sstevel@tonic-gate * Dyn.d_un.d_val field of the Elf*_Dyn structure. 1750Sstevel@tonic-gate */ 1760Sstevel@tonic-gate #define DT_VALRNGLO 0x6ffffd00 1779085SAli.Bahrami@Sun.COM 1789085SAli.Bahrami@Sun.COM #define DT_GNU_PRELINKED 0x6ffffdf5 /* prelinking timestamp (unused) */ 1799085SAli.Bahrami@Sun.COM #define DT_GNU_CONFLICTSZ 0x6ffffdf6 /* size of conflict section (unused) */ 1809085SAli.Bahrami@Sun.COM #define DT_GNU_LIBLISTSZ 0x6ffffdf7 /* size of library list (unused) */ 1810Sstevel@tonic-gate #define DT_CHECKSUM 0x6ffffdf8 /* elf checksum */ 1820Sstevel@tonic-gate #define DT_PLTPADSZ 0x6ffffdf9 /* pltpadding size */ 1830Sstevel@tonic-gate #define DT_MOVEENT 0x6ffffdfa /* move table entry size */ 1840Sstevel@tonic-gate #define DT_MOVESZ 0x6ffffdfb /* move table size */ 185*12992SRod.Evans@Oracle.COM #define DT_FEATURE_1 0x6ffffdfc /* feature holder (unused) */ 1860Sstevel@tonic-gate #define DT_POSFLAG_1 0x6ffffdfd /* flags for DT_* entries, effecting */ 1870Sstevel@tonic-gate /* the following DT_* entry. */ 1880Sstevel@tonic-gate /* See DF_P1_* definitions */ 1890Sstevel@tonic-gate #define DT_SYMINSZ 0x6ffffdfe /* syminfo table size (in bytes) */ 1900Sstevel@tonic-gate #define DT_SYMINENT 0x6ffffdff /* syminfo entry size (in bytes) */ 1910Sstevel@tonic-gate #define DT_VALRNGHI 0x6ffffdff 1920Sstevel@tonic-gate 1930Sstevel@tonic-gate /* 1940Sstevel@tonic-gate * DT_* entries which fall between DT_ADDRRNGHI & DT_ADDRRNGLO use the 1950Sstevel@tonic-gate * Dyn.d_un.d_ptr field of the Elf*_Dyn structure. 1960Sstevel@tonic-gate * 1970Sstevel@tonic-gate * If any adjustment is made to the ELF object after it has been 1980Sstevel@tonic-gate * built, these entries will need to be adjusted. 1990Sstevel@tonic-gate */ 2000Sstevel@tonic-gate #define DT_ADDRRNGLO 0x6ffffe00 2019085SAli.Bahrami@Sun.COM 2029085SAli.Bahrami@Sun.COM #define DT_GNU_HASH 0x6ffffef5 /* GNU-style hash table (unused) */ 2039085SAli.Bahrami@Sun.COM #define DT_TLSDESC_PLT 0x6ffffef6 /* GNU (unused) */ 2049085SAli.Bahrami@Sun.COM #define DT_TLSDESC_GOT 0x6ffffef7 /* GNU (unused) */ 2059085SAli.Bahrami@Sun.COM #define DT_GNU_CONFLICT 0x6ffffef8 /* start of conflict section (unused) */ 2069085SAli.Bahrami@Sun.COM #define DT_GNU_LIBLIST 0x6ffffef9 /* Library list (unused) */ 2079085SAli.Bahrami@Sun.COM 2080Sstevel@tonic-gate #define DT_CONFIG 0x6ffffefa /* configuration information */ 2090Sstevel@tonic-gate #define DT_DEPAUDIT 0x6ffffefb /* dependency auditing */ 2100Sstevel@tonic-gate #define DT_AUDIT 0x6ffffefc /* object auditing */ 2110Sstevel@tonic-gate #define DT_PLTPAD 0x6ffffefd /* pltpadding (sparcv9) */ 2120Sstevel@tonic-gate #define DT_MOVETAB 0x6ffffefe /* move table */ 2130Sstevel@tonic-gate #define DT_SYMINFO 0x6ffffeff /* syminfo table */ 2140Sstevel@tonic-gate #define DT_ADDRRNGHI 0x6ffffeff 2150Sstevel@tonic-gate 2160Sstevel@tonic-gate /* 2170Sstevel@tonic-gate * The following DT_* entries should have been assigned within one of the 2180Sstevel@tonic-gate * DT_* ranges, but existed before such ranges had been established. 2190Sstevel@tonic-gate */ 2204716Sab196087 #define DT_VERSYM 0x6ffffff0 /* version symbol table - unused by */ 2214716Sab196087 /* Solaris (see libld/update.c) */ 2220Sstevel@tonic-gate 2230Sstevel@tonic-gate #define DT_RELACOUNT 0x6ffffff9 /* number of RELATIVE relocations */ 2240Sstevel@tonic-gate #define DT_RELCOUNT 0x6ffffffa /* number of RELATIVE relocations */ 2250Sstevel@tonic-gate #define DT_FLAGS_1 0x6ffffffb /* state flags - see DF_1_* defs */ 2260Sstevel@tonic-gate #define DT_VERDEF 0x6ffffffc /* version definition table and */ 2270Sstevel@tonic-gate #define DT_VERDEFNUM 0x6ffffffd /* associated no. of entries */ 2280Sstevel@tonic-gate #define DT_VERNEED 0x6ffffffe /* version needed table and */ 2290Sstevel@tonic-gate #define DT_VERNEEDNUM 0x6fffffff /* associated no. of entries */ 2300Sstevel@tonic-gate 2310Sstevel@tonic-gate /* 2320Sstevel@tonic-gate * DT_* entries between DT_HIPROC and DT_LOPROC are reserved for processor 2330Sstevel@tonic-gate * specific semantics. 2343492Sab196087 * 2353492Sab196087 * DT_* encoding rules apply to all tag values larger than DT_LOPROC. 2360Sstevel@tonic-gate */ 2370Sstevel@tonic-gate #define DT_LOPROC 0x70000000 /* processor specific range */ 2380Sstevel@tonic-gate #define DT_AUXILIARY 0x7ffffffd /* shared library auxiliary name */ 2390Sstevel@tonic-gate #define DT_USED 0x7ffffffe /* ignored - same as needed */ 2400Sstevel@tonic-gate #define DT_FILTER 0x7fffffff /* shared library filter name */ 2410Sstevel@tonic-gate #define DT_HIPROC 0x7fffffff 2420Sstevel@tonic-gate 2430Sstevel@tonic-gate 2440Sstevel@tonic-gate /* 2450Sstevel@tonic-gate * Values for DT_FLAGS 2460Sstevel@tonic-gate */ 2470Sstevel@tonic-gate #define DF_ORIGIN 0x00000001 /* ORIGIN processing required */ 2480Sstevel@tonic-gate #define DF_SYMBOLIC 0x00000002 /* symbolic bindings in effect */ 2490Sstevel@tonic-gate #define DF_TEXTREL 0x00000004 /* text relocations remain */ 2500Sstevel@tonic-gate #define DF_BIND_NOW 0x00000008 /* process all relocations */ 2510Sstevel@tonic-gate #define DF_STATIC_TLS 0x00000010 /* obj. contains static TLS refs */ 2520Sstevel@tonic-gate 2530Sstevel@tonic-gate /* 2540Sstevel@tonic-gate * Values for the DT_POSFLAG_1 .dynamic entry. 2550Sstevel@tonic-gate * These values only affect the following DT_* entry. 2560Sstevel@tonic-gate */ 2570Sstevel@tonic-gate #define DF_P1_LAZYLOAD 0x00000001 /* following object is to be */ 2580Sstevel@tonic-gate /* lazy loaded */ 2590Sstevel@tonic-gate #define DF_P1_GROUPPERM 0x00000002 /* following object's symbols are */ 2600Sstevel@tonic-gate /* not available for general */ 2610Sstevel@tonic-gate /* symbol bindings. */ 26212449SRod.Evans@Sun.COM #define DF_P1_DEFERRED 0x00000004 /* following object is deferred */ 26312449SRod.Evans@Sun.COM 2640Sstevel@tonic-gate /* 2650Sstevel@tonic-gate * Values for the DT_FLAGS_1 .dynamic entry. 2660Sstevel@tonic-gate */ 2670Sstevel@tonic-gate #define DF_1_NOW 0x00000001 /* set RTLD_NOW for this object */ 2680Sstevel@tonic-gate #define DF_1_GLOBAL 0x00000002 /* set RTLD_GLOBAL for this object */ 2690Sstevel@tonic-gate #define DF_1_GROUP 0x00000004 /* set RTLD_GROUP for this object */ 2700Sstevel@tonic-gate #define DF_1_NODELETE 0x00000008 /* set RTLD_NODELETE for this object */ 2710Sstevel@tonic-gate #define DF_1_LOADFLTR 0x00000010 /* trigger filtee loading at runtime */ 2720Sstevel@tonic-gate #define DF_1_INITFIRST 0x00000020 /* set RTLD_INITFIRST for this object */ 2730Sstevel@tonic-gate #define DF_1_NOOPEN 0x00000040 /* set RTLD_NOOPEN for this object */ 2740Sstevel@tonic-gate #define DF_1_ORIGIN 0x00000080 /* ORIGIN processing required */ 2750Sstevel@tonic-gate #define DF_1_DIRECT 0x00000100 /* direct binding enabled */ 276*12992SRod.Evans@Oracle.COM #define DF_1_TRANS 0x00000200 /* unused obsolete name */ 2773466Srie #define DF_1_INTERPOSE 0x00000400 /* object is an interposer */ 2780Sstevel@tonic-gate #define DF_1_NODEFLIB 0x00000800 /* ignore default library search path */ 2790Sstevel@tonic-gate #define DF_1_NODUMP 0x00001000 /* object can't be dldump(3x)'ed */ 2800Sstevel@tonic-gate #define DF_1_CONFALT 0x00002000 /* configuration alternative created */ 2810Sstevel@tonic-gate #define DF_1_ENDFILTEE 0x00004000 /* filtee terminates filters search */ 2820Sstevel@tonic-gate #define DF_1_DISPRELDNE 0x00008000 /* disp reloc applied at build time */ 2830Sstevel@tonic-gate #define DF_1_DISPRELPND 0x00010000 /* disp reloc applied at run-time */ 2840Sstevel@tonic-gate #define DF_1_NODIRECT 0x00020000 /* object contains symbols that */ 2850Sstevel@tonic-gate /* cannot be directly bound to */ 2861682Srie #define DF_1_IGNMULDEF 0x00040000 /* internal: krtld ignore muldefs */ 2871682Srie #define DF_1_NOKSYMS 0x00080000 /* internal: don't export object's */ 2881682Srie /* symbols via /dev/ksyms */ 28911734SAli.Bahrami@Sun.COM #define DF_1_NOHDR 0x00100000 /* mapfile: 1st segment mapping */ 2901698Sab196087 /* omits ELF & program headers */ 2913850Sab196087 #define DF_1_EDITED 0x00200000 /* object has been modified since */ 2923850Sab196087 /* being built by 'ld' */ 2931682Srie #define DF_1_NORELOC 0x00400000 /* internal: unrelocated object */ 2943466Srie #define DF_1_SYMINTPOSE 0x00800000 /* individual symbol interposers */ 2953466Srie /* exist */ 2964679Srie #define DF_1_GLOBAUDIT 0x01000000 /* establish global auditing */ 2975220Srie #define DF_1_SINGLETON 0x02000000 /* singleton symbols exist */ 2980Sstevel@tonic-gate 2990Sstevel@tonic-gate /* 300*12992SRod.Evans@Oracle.COM * Values set to DT_FEATURE_1 tag's d_val (unused obsolete tag) 3010Sstevel@tonic-gate */ 3020Sstevel@tonic-gate #define DTF_1_PARINIT 0x00000001 /* partially initialization feature */ 3030Sstevel@tonic-gate #define DTF_1_CONFEXP 0x00000002 /* configuration file expected */ 3040Sstevel@tonic-gate 3050Sstevel@tonic-gate 3060Sstevel@tonic-gate /* 3070Sstevel@tonic-gate * Version structures. There are three types of version structure: 3080Sstevel@tonic-gate * 3090Sstevel@tonic-gate * o A definition of the versions within the image itself. 3100Sstevel@tonic-gate * Each version definition is assigned a unique index (starting from 3110Sstevel@tonic-gate * VER_NDX_BGNDEF) which is used to cross-reference symbols associated to 3120Sstevel@tonic-gate * the version. Each version can have one or more dependencies on other 3130Sstevel@tonic-gate * version definitions within the image. The version name, and any 3140Sstevel@tonic-gate * dependency names, are specified in the version definition auxiliary 3150Sstevel@tonic-gate * array. Version definition entries require a version symbol index table. 3160Sstevel@tonic-gate * 3170Sstevel@tonic-gate * o A version requirement on a needed dependency. Each needed entry 3180Sstevel@tonic-gate * specifies the shared object dependency (as specified in DT_NEEDED). 3190Sstevel@tonic-gate * One or more versions required from this dependency are specified in the 3200Sstevel@tonic-gate * version needed auxiliary array. 3210Sstevel@tonic-gate * 3220Sstevel@tonic-gate * o A version symbol index table. Each symbol indexes into this array 3230Sstevel@tonic-gate * to determine its version index. Index values of VER_NDX_BGNDEF or 3240Sstevel@tonic-gate * greater indicate the version definition to which a symbol is associated. 3250Sstevel@tonic-gate * (the size of a symbol index entry is recorded in the sh_info field). 3260Sstevel@tonic-gate */ 3270Sstevel@tonic-gate #ifndef _ASM 3280Sstevel@tonic-gate 3290Sstevel@tonic-gate typedef struct { /* Version Definition Structure. */ 3300Sstevel@tonic-gate Elf32_Half vd_version; /* this structures version revision */ 3310Sstevel@tonic-gate Elf32_Half vd_flags; /* version information */ 3320Sstevel@tonic-gate Elf32_Half vd_ndx; /* version index */ 3330Sstevel@tonic-gate Elf32_Half vd_cnt; /* no. of associated aux entries */ 3340Sstevel@tonic-gate Elf32_Word vd_hash; /* version name hash value */ 3350Sstevel@tonic-gate Elf32_Word vd_aux; /* no. of bytes from start of this */ 3360Sstevel@tonic-gate /* verdef to verdaux array */ 3370Sstevel@tonic-gate Elf32_Word vd_next; /* no. of bytes from start of this */ 3380Sstevel@tonic-gate } Elf32_Verdef; /* verdef to next verdef entry */ 3390Sstevel@tonic-gate 3400Sstevel@tonic-gate typedef struct { /* Verdef Auxiliary Structure. */ 3410Sstevel@tonic-gate Elf32_Word vda_name; /* first element defines the version */ 3420Sstevel@tonic-gate /* name. Additional entries */ 3430Sstevel@tonic-gate /* define dependency names. */ 3440Sstevel@tonic-gate Elf32_Word vda_next; /* no. of bytes from start of this */ 3450Sstevel@tonic-gate } Elf32_Verdaux; /* verdaux to next verdaux entry */ 3460Sstevel@tonic-gate 3470Sstevel@tonic-gate 3480Sstevel@tonic-gate typedef struct { /* Version Requirement Structure. */ 3490Sstevel@tonic-gate Elf32_Half vn_version; /* this structures version revision */ 3500Sstevel@tonic-gate Elf32_Half vn_cnt; /* no. of associated aux entries */ 3510Sstevel@tonic-gate Elf32_Word vn_file; /* name of needed dependency (file) */ 3520Sstevel@tonic-gate Elf32_Word vn_aux; /* no. of bytes from start of this */ 3530Sstevel@tonic-gate /* verneed to vernaux array */ 3540Sstevel@tonic-gate Elf32_Word vn_next; /* no. of bytes from start of this */ 3550Sstevel@tonic-gate } Elf32_Verneed; /* verneed to next verneed entry */ 3560Sstevel@tonic-gate 3570Sstevel@tonic-gate typedef struct { /* Verneed Auxiliary Structure. */ 3580Sstevel@tonic-gate Elf32_Word vna_hash; /* version name hash value */ 3590Sstevel@tonic-gate Elf32_Half vna_flags; /* version information */ 3600Sstevel@tonic-gate Elf32_Half vna_other; 3610Sstevel@tonic-gate Elf32_Word vna_name; /* version name */ 3620Sstevel@tonic-gate Elf32_Word vna_next; /* no. of bytes from start of this */ 3630Sstevel@tonic-gate } Elf32_Vernaux; /* vernaux to next vernaux entry */ 3640Sstevel@tonic-gate 3650Sstevel@tonic-gate typedef Elf32_Half Elf32_Versym; /* Version symbol index array */ 3660Sstevel@tonic-gate 3670Sstevel@tonic-gate typedef struct { 3680Sstevel@tonic-gate Elf32_Half si_boundto; /* direct bindings - symbol bound to */ 3690Sstevel@tonic-gate Elf32_Half si_flags; /* per symbol flags */ 3700Sstevel@tonic-gate } Elf32_Syminfo; 3710Sstevel@tonic-gate 3720Sstevel@tonic-gate 3730Sstevel@tonic-gate #if defined(_LP64) || defined(_LONGLONG_TYPE) 3740Sstevel@tonic-gate typedef struct { 3750Sstevel@tonic-gate Elf64_Half vd_version; /* this structures version revision */ 3760Sstevel@tonic-gate Elf64_Half vd_flags; /* version information */ 3770Sstevel@tonic-gate Elf64_Half vd_ndx; /* version index */ 3780Sstevel@tonic-gate Elf64_Half vd_cnt; /* no. of associated aux entries */ 3790Sstevel@tonic-gate Elf64_Word vd_hash; /* version name hash value */ 3800Sstevel@tonic-gate Elf64_Word vd_aux; /* no. of bytes from start of this */ 3810Sstevel@tonic-gate /* verdef to verdaux array */ 3820Sstevel@tonic-gate Elf64_Word vd_next; /* no. of bytes from start of this */ 3830Sstevel@tonic-gate } Elf64_Verdef; /* verdef to next verdef entry */ 3840Sstevel@tonic-gate 3850Sstevel@tonic-gate typedef struct { 3860Sstevel@tonic-gate Elf64_Word vda_name; /* first element defines the version */ 3870Sstevel@tonic-gate /* name. Additional entries */ 3880Sstevel@tonic-gate /* define dependency names. */ 3890Sstevel@tonic-gate Elf64_Word vda_next; /* no. of bytes from start of this */ 3900Sstevel@tonic-gate } Elf64_Verdaux; /* verdaux to next verdaux entry */ 3910Sstevel@tonic-gate 3920Sstevel@tonic-gate typedef struct { 3930Sstevel@tonic-gate Elf64_Half vn_version; /* this structures version revision */ 3940Sstevel@tonic-gate Elf64_Half vn_cnt; /* no. of associated aux entries */ 3950Sstevel@tonic-gate Elf64_Word vn_file; /* name of needed dependency (file) */ 3960Sstevel@tonic-gate Elf64_Word vn_aux; /* no. of bytes from start of this */ 3970Sstevel@tonic-gate /* verneed to vernaux array */ 3980Sstevel@tonic-gate Elf64_Word vn_next; /* no. of bytes from start of this */ 3990Sstevel@tonic-gate } Elf64_Verneed; /* verneed to next verneed entry */ 4000Sstevel@tonic-gate 4010Sstevel@tonic-gate typedef struct { 4020Sstevel@tonic-gate Elf64_Word vna_hash; /* version name hash value */ 4030Sstevel@tonic-gate Elf64_Half vna_flags; /* version information */ 4040Sstevel@tonic-gate Elf64_Half vna_other; 4050Sstevel@tonic-gate Elf64_Word vna_name; /* version name */ 4060Sstevel@tonic-gate Elf64_Word vna_next; /* no. of bytes from start of this */ 4070Sstevel@tonic-gate } Elf64_Vernaux; /* vernaux to next vernaux entry */ 4080Sstevel@tonic-gate 4090Sstevel@tonic-gate typedef Elf64_Half Elf64_Versym; 4100Sstevel@tonic-gate 4110Sstevel@tonic-gate typedef struct { 4120Sstevel@tonic-gate Elf64_Half si_boundto; /* direct bindings - symbol bound to */ 4130Sstevel@tonic-gate Elf64_Half si_flags; /* per symbol flags */ 4140Sstevel@tonic-gate } Elf64_Syminfo; 4150Sstevel@tonic-gate #endif /* defined(_LP64) || defined(_LONGLONG_TYPE) */ 4160Sstevel@tonic-gate 4170Sstevel@tonic-gate #endif /* _ASM */ 4180Sstevel@tonic-gate 4190Sstevel@tonic-gate /* 4200Sstevel@tonic-gate * Versym symbol index values. Values greater than VER_NDX_GLOBAL 4210Sstevel@tonic-gate * and less then VER_NDX_LORESERVE associate symbols with user 4220Sstevel@tonic-gate * specified version descriptors. 4230Sstevel@tonic-gate */ 4240Sstevel@tonic-gate #define VER_NDX_LOCAL 0 /* symbol is local */ 4250Sstevel@tonic-gate #define VER_NDX_GLOBAL 1 /* symbol is global and assigned to */ 4260Sstevel@tonic-gate /* the base version */ 4270Sstevel@tonic-gate #define VER_NDX_LORESERVE 0xff00 /* beginning of RESERVED entries */ 4280Sstevel@tonic-gate #define VER_NDX_ELIMINATE 0xff01 /* symbol is to be eliminated */ 4290Sstevel@tonic-gate 4300Sstevel@tonic-gate /* 4317682SAli.Bahrami@Sun.COM * Verdef (vd_flags) and Vernaux (vna_flags) flags values. 4320Sstevel@tonic-gate */ 4330Sstevel@tonic-gate #define VER_FLG_BASE 0x1 /* version definition of file itself */ 4347682SAli.Bahrami@Sun.COM /* (Verdef only) */ 4350Sstevel@tonic-gate #define VER_FLG_WEAK 0x2 /* weak version identifier */ 4367682SAli.Bahrami@Sun.COM #define VER_FLG_INFO 0x4 /* version is recorded in object for */ 4377682SAli.Bahrami@Sun.COM /* informational purposes */ 4387682SAli.Bahrami@Sun.COM /* (Versym reference) only. No */ 4397682SAli.Bahrami@Sun.COM /* runtime verification is */ 4407682SAli.Bahrami@Sun.COM /* required. (Vernaux only) */ 4410Sstevel@tonic-gate 4420Sstevel@tonic-gate /* 4430Sstevel@tonic-gate * Verdef version values. 4440Sstevel@tonic-gate */ 4450Sstevel@tonic-gate #define VER_DEF_NONE 0 /* Ver_def version */ 4460Sstevel@tonic-gate #define VER_DEF_CURRENT 1 4470Sstevel@tonic-gate #define VER_DEF_NUM 2 4480Sstevel@tonic-gate 4490Sstevel@tonic-gate /* 4500Sstevel@tonic-gate * Verneed version values. 4510Sstevel@tonic-gate */ 4520Sstevel@tonic-gate #define VER_NEED_NONE 0 /* Ver_need version */ 4530Sstevel@tonic-gate #define VER_NEED_CURRENT 1 4540Sstevel@tonic-gate #define VER_NEED_NUM 2 4550Sstevel@tonic-gate 4560Sstevel@tonic-gate 4570Sstevel@tonic-gate /* 4580Sstevel@tonic-gate * Syminfo flag values 4590Sstevel@tonic-gate */ 4600Sstevel@tonic-gate #define SYMINFO_FLG_DIRECT 0x0001 /* symbol ref has direct association */ 4610Sstevel@tonic-gate /* to object containing defn. */ 4629273SAli.Bahrami@Sun.COM #define SYMINFO_FLG_FILTER 0x0002 /* symbol ref is associated to a */ 4639273SAli.Bahrami@Sun.COM /* standard filter */ 464*12992SRod.Evans@Oracle.COM #define SYMINFO_FLG_PASSTHRU SYMINFO_FLG_FILTER /* unused obsolete name */ 4650Sstevel@tonic-gate #define SYMINFO_FLG_COPY 0x0004 /* symbol is a copy-reloc */ 4663466Srie #define SYMINFO_FLG_LAZYLOAD 0x0008 /* object containing defn. should be */ 4670Sstevel@tonic-gate /* lazily-loaded */ 4680Sstevel@tonic-gate #define SYMINFO_FLG_DIRECTBIND 0x0010 /* ref should be bound directly to */ 4690Sstevel@tonic-gate /* object containing defn. */ 4700Sstevel@tonic-gate #define SYMINFO_FLG_NOEXTDIRECT 0x0020 /* don't let an external reference */ 4710Sstevel@tonic-gate /* directly bind to this symbol */ 4729273SAli.Bahrami@Sun.COM #define SYMINFO_FLG_AUXILIARY 0x0040 /* symbol ref is associated to a */ 4739273SAli.Bahrami@Sun.COM /* auxiliary filter */ 4743466Srie #define SYMINFO_FLG_INTERPOSE 0x0080 /* symbol defines an interposer */ 47511827SRod.Evans@Sun.COM #define SYMINFO_FLG_CAP 0x0100 /* symbol is capabilities specific */ 47612449SRod.Evans@Sun.COM #define SYMINFO_FLG_DEFERRED 0x0200 /* symbol should not be included in */ 47712449SRod.Evans@Sun.COM /* BIND_NOW relocations */ 4780Sstevel@tonic-gate 4790Sstevel@tonic-gate /* 4800Sstevel@tonic-gate * Syminfo.si_boundto values. 4810Sstevel@tonic-gate */ 4820Sstevel@tonic-gate #define SYMINFO_BT_SELF 0xffff /* symbol bound to self */ 4830Sstevel@tonic-gate #define SYMINFO_BT_PARENT 0xfffe /* symbol bound to parent */ 4840Sstevel@tonic-gate #define SYMINFO_BT_NONE 0xfffd /* no special symbol binding */ 4850Sstevel@tonic-gate #define SYMINFO_BT_EXTERN 0xfffc /* symbol defined as external */ 4860Sstevel@tonic-gate #define SYMINFO_BT_LOWRESERVE 0xff00 /* beginning of reserved entries */ 4870Sstevel@tonic-gate 4880Sstevel@tonic-gate /* 4890Sstevel@tonic-gate * Syminfo version values. 4900Sstevel@tonic-gate */ 4910Sstevel@tonic-gate #define SYMINFO_NONE 0 /* Syminfo version */ 4920Sstevel@tonic-gate #define SYMINFO_CURRENT 1 4930Sstevel@tonic-gate #define SYMINFO_NUM 2 4940Sstevel@tonic-gate 4950Sstevel@tonic-gate 4960Sstevel@tonic-gate /* 4970Sstevel@tonic-gate * Public structure defined and maintained within the runtime linker 4980Sstevel@tonic-gate */ 4990Sstevel@tonic-gate #ifndef _ASM 5000Sstevel@tonic-gate 5010Sstevel@tonic-gate typedef struct link_map Link_map; 5020Sstevel@tonic-gate 5030Sstevel@tonic-gate struct link_map { 5040Sstevel@tonic-gate unsigned long l_addr; /* address at which object is mapped */ 5050Sstevel@tonic-gate char *l_name; /* full name of loaded object */ 5060Sstevel@tonic-gate #ifdef _LP64 5070Sstevel@tonic-gate Elf64_Dyn *l_ld; /* dynamic structure of object */ 5080Sstevel@tonic-gate #else 5090Sstevel@tonic-gate Elf32_Dyn *l_ld; /* dynamic structure of object */ 5100Sstevel@tonic-gate #endif 5110Sstevel@tonic-gate Link_map *l_next; /* next link object */ 5120Sstevel@tonic-gate Link_map *l_prev; /* previous link object */ 5130Sstevel@tonic-gate char *l_refname; /* filters reference name */ 5140Sstevel@tonic-gate }; 5150Sstevel@tonic-gate 5160Sstevel@tonic-gate #ifdef _SYSCALL32 5170Sstevel@tonic-gate typedef struct link_map32 Link_map32; 5180Sstevel@tonic-gate 5190Sstevel@tonic-gate struct link_map32 { 5200Sstevel@tonic-gate Elf32_Word l_addr; 5210Sstevel@tonic-gate Elf32_Addr l_name; 5220Sstevel@tonic-gate Elf32_Addr l_ld; 5230Sstevel@tonic-gate Elf32_Addr l_next; 5240Sstevel@tonic-gate Elf32_Addr l_prev; 5250Sstevel@tonic-gate Elf32_Addr l_refname; 5260Sstevel@tonic-gate }; 5270Sstevel@tonic-gate #endif 5280Sstevel@tonic-gate 5290Sstevel@tonic-gate typedef enum { 5300Sstevel@tonic-gate RT_CONSISTENT, 5310Sstevel@tonic-gate RT_ADD, 5320Sstevel@tonic-gate RT_DELETE 5330Sstevel@tonic-gate } r_state_e; 5340Sstevel@tonic-gate 5350Sstevel@tonic-gate typedef enum { 5360Sstevel@tonic-gate RD_FL_NONE = 0, /* no flags */ 5370Sstevel@tonic-gate RD_FL_ODBG = (1<<0), /* old style debugger present */ 5380Sstevel@tonic-gate RD_FL_DBG = (1<<1) /* debugging enabled */ 5390Sstevel@tonic-gate } rd_flags_e; 5400Sstevel@tonic-gate 5410Sstevel@tonic-gate 5420Sstevel@tonic-gate 5430Sstevel@tonic-gate /* 5440Sstevel@tonic-gate * Debugging events enabled inside of the runtime linker. To 5450Sstevel@tonic-gate * access these events see the librtld_db interface. 5460Sstevel@tonic-gate */ 5470Sstevel@tonic-gate typedef enum { 5480Sstevel@tonic-gate RD_NONE = 0, /* no event */ 5490Sstevel@tonic-gate RD_PREINIT, /* the Initial rendezvous before .init */ 5500Sstevel@tonic-gate RD_POSTINIT, /* the Second rendezvous after .init */ 5510Sstevel@tonic-gate RD_DLACTIVITY /* a dlopen or dlclose has happened */ 5520Sstevel@tonic-gate } rd_event_e; 5530Sstevel@tonic-gate 5540Sstevel@tonic-gate struct r_debug { 5550Sstevel@tonic-gate int r_version; /* debugging info version no. */ 5560Sstevel@tonic-gate Link_map *r_map; /* address of link_map */ 5570Sstevel@tonic-gate unsigned long r_brk; /* address of update routine */ 5580Sstevel@tonic-gate r_state_e r_state; 5590Sstevel@tonic-gate unsigned long r_ldbase; /* base addr of ld.so */ 5600Sstevel@tonic-gate Link_map *r_ldsomap; /* address of ld.so.1's link map */ 5610Sstevel@tonic-gate rd_event_e r_rdevent; /* debug event */ 5620Sstevel@tonic-gate rd_flags_e r_flags; /* misc flags. */ 5630Sstevel@tonic-gate }; 5640Sstevel@tonic-gate 5650Sstevel@tonic-gate #ifdef _SYSCALL32 5660Sstevel@tonic-gate struct r_debug32 { 5670Sstevel@tonic-gate Elf32_Word r_version; /* debugging info version no. */ 5680Sstevel@tonic-gate Elf32_Addr r_map; /* address of link_map */ 5690Sstevel@tonic-gate Elf32_Word r_brk; /* address of update routine */ 5700Sstevel@tonic-gate r_state_e r_state; 5710Sstevel@tonic-gate Elf32_Word r_ldbase; /* base addr of ld.so */ 5720Sstevel@tonic-gate Elf32_Addr r_ldsomap; /* address of ld.so.1's link map */ 5730Sstevel@tonic-gate rd_event_e r_rdevent; /* debug event */ 5740Sstevel@tonic-gate rd_flags_e r_flags; /* misc flags. */ 5750Sstevel@tonic-gate }; 5760Sstevel@tonic-gate #endif 5770Sstevel@tonic-gate 5780Sstevel@tonic-gate 5790Sstevel@tonic-gate #define R_DEBUG_VERSION 2 /* current r_debug version */ 5800Sstevel@tonic-gate #endif /* _ASM */ 5810Sstevel@tonic-gate 5820Sstevel@tonic-gate /* 5830Sstevel@tonic-gate * Attribute/value structures used to bootstrap ELF-based dynamic linker. 5840Sstevel@tonic-gate */ 5850Sstevel@tonic-gate #ifndef _ASM 5860Sstevel@tonic-gate typedef struct { 5870Sstevel@tonic-gate Elf32_Sword eb_tag; /* what this one is */ 5880Sstevel@tonic-gate union { /* possible values */ 5890Sstevel@tonic-gate Elf32_Word eb_val; 5900Sstevel@tonic-gate Elf32_Addr eb_ptr; 5910Sstevel@tonic-gate Elf32_Off eb_off; 5920Sstevel@tonic-gate } eb_un; 5930Sstevel@tonic-gate } Elf32_Boot; 5940Sstevel@tonic-gate 5950Sstevel@tonic-gate #if defined(_LP64) || defined(_LONGLONG_TYPE) 5960Sstevel@tonic-gate typedef struct { 5970Sstevel@tonic-gate Elf64_Xword eb_tag; /* what this one is */ 5980Sstevel@tonic-gate union { /* possible values */ 5990Sstevel@tonic-gate Elf64_Xword eb_val; 6000Sstevel@tonic-gate Elf64_Addr eb_ptr; 6010Sstevel@tonic-gate Elf64_Off eb_off; 6020Sstevel@tonic-gate } eb_un; 6030Sstevel@tonic-gate } Elf64_Boot; 6040Sstevel@tonic-gate #endif /* defined(_LP64) || defined(_LONGLONG_TYPE) */ 6050Sstevel@tonic-gate #endif /* _ASM */ 6060Sstevel@tonic-gate 6070Sstevel@tonic-gate /* 6080Sstevel@tonic-gate * Attributes 6090Sstevel@tonic-gate */ 6100Sstevel@tonic-gate #define EB_NULL 0 /* (void) last entry */ 6110Sstevel@tonic-gate #define EB_DYNAMIC 1 /* (*) dynamic structure of subject */ 6120Sstevel@tonic-gate #define EB_LDSO_BASE 2 /* (caddr_t) base address of ld.so */ 6130Sstevel@tonic-gate #define EB_ARGV 3 /* (caddr_t) argument vector */ 6140Sstevel@tonic-gate #define EB_ENVP 4 /* (char **) environment strings */ 6150Sstevel@tonic-gate #define EB_AUXV 5 /* (auxv_t *) auxiliary vector */ 6160Sstevel@tonic-gate #define EB_DEVZERO 6 /* (int) fd for /dev/zero */ 6170Sstevel@tonic-gate #define EB_PAGESIZE 7 /* (int) page size */ 6180Sstevel@tonic-gate #define EB_MAX 8 /* number of "EBs" */ 6190Sstevel@tonic-gate #define EB_MAX_SIZE32 64 /* size in bytes, _ILP32 */ 6200Sstevel@tonic-gate #define EB_MAX_SIZE64 128 /* size in bytes, _LP64 */ 6210Sstevel@tonic-gate 6220Sstevel@tonic-gate 6230Sstevel@tonic-gate #ifndef _ASM 6240Sstevel@tonic-gate 6250Sstevel@tonic-gate #ifdef __STDC__ 6260Sstevel@tonic-gate 6270Sstevel@tonic-gate /* 6280Sstevel@tonic-gate * Concurrency communication structure for libc callbacks. 6290Sstevel@tonic-gate */ 6300Sstevel@tonic-gate extern void _ld_libc(void *); 6310Sstevel@tonic-gate #else /* __STDC__ */ 6320Sstevel@tonic-gate extern void _ld_libc(); 6330Sstevel@tonic-gate #endif /* __STDC__ */ 6340Sstevel@tonic-gate 6350Sstevel@tonic-gate #pragma unknown_control_flow(_ld_libc) 6360Sstevel@tonic-gate #endif /* _ASM */ 6370Sstevel@tonic-gate 6380Sstevel@tonic-gate #ifdef __cplusplus 6390Sstevel@tonic-gate } 6400Sstevel@tonic-gate #endif 6410Sstevel@tonic-gate 6420Sstevel@tonic-gate #endif /* _SYS_LINK_H */ 643