1*0Sstevel@tonic-gate /* 2*0Sstevel@tonic-gate * CDDL HEADER START 3*0Sstevel@tonic-gate * 4*0Sstevel@tonic-gate * The contents of this file are subject to the terms of the 5*0Sstevel@tonic-gate * Common Development and Distribution License, Version 1.0 only 6*0Sstevel@tonic-gate * (the "License"). You may not use this file except in compliance 7*0Sstevel@tonic-gate * with the License. 8*0Sstevel@tonic-gate * 9*0Sstevel@tonic-gate * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 10*0Sstevel@tonic-gate * or http://www.opensolaris.org/os/licensing. 11*0Sstevel@tonic-gate * See the License for the specific language governing permissions 12*0Sstevel@tonic-gate * and limitations under the License. 13*0Sstevel@tonic-gate * 14*0Sstevel@tonic-gate * When distributing Covered Code, include this CDDL HEADER in each 15*0Sstevel@tonic-gate * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 16*0Sstevel@tonic-gate * If applicable, add the following below this CDDL HEADER, with the 17*0Sstevel@tonic-gate * fields enclosed by brackets "[]" replaced with your own identifying 18*0Sstevel@tonic-gate * information: Portions Copyright [yyyy] [name of copyright owner] 19*0Sstevel@tonic-gate * 20*0Sstevel@tonic-gate * CDDL HEADER END 21*0Sstevel@tonic-gate */ 22*0Sstevel@tonic-gate /* Copyright (c) 1988 AT&T */ 23*0Sstevel@tonic-gate /* All Rights Reserved */ 24*0Sstevel@tonic-gate 25*0Sstevel@tonic-gate 26*0Sstevel@tonic-gate /* 27*0Sstevel@tonic-gate * Copyright 2005 Sun Microsystems, Inc. All rights reserved. 28*0Sstevel@tonic-gate * Use is subject to license terms. 29*0Sstevel@tonic-gate */ 30*0Sstevel@tonic-gate 31*0Sstevel@tonic-gate #ifndef _SYS_LINK_H 32*0Sstevel@tonic-gate #define _SYS_LINK_H 33*0Sstevel@tonic-gate 34*0Sstevel@tonic-gate #pragma ident "%Z%%M% %I% %E% SMI" 35*0Sstevel@tonic-gate 36*0Sstevel@tonic-gate #ifndef _ASM 37*0Sstevel@tonic-gate #include <sys/types.h> 38*0Sstevel@tonic-gate #include <sys/elftypes.h> 39*0Sstevel@tonic-gate #endif 40*0Sstevel@tonic-gate 41*0Sstevel@tonic-gate #ifdef __cplusplus 42*0Sstevel@tonic-gate extern "C" { 43*0Sstevel@tonic-gate #endif 44*0Sstevel@tonic-gate 45*0Sstevel@tonic-gate /* 46*0Sstevel@tonic-gate * Communication structures for the runtime linker. 47*0Sstevel@tonic-gate */ 48*0Sstevel@tonic-gate 49*0Sstevel@tonic-gate /* 50*0Sstevel@tonic-gate * The following data structure provides a self-identifying union consisting 51*0Sstevel@tonic-gate * of a tag from a known list and a value. 52*0Sstevel@tonic-gate */ 53*0Sstevel@tonic-gate #ifndef _ASM 54*0Sstevel@tonic-gate typedef struct { 55*0Sstevel@tonic-gate Elf32_Sword d_tag; /* how to interpret value */ 56*0Sstevel@tonic-gate union { 57*0Sstevel@tonic-gate Elf32_Word d_val; 58*0Sstevel@tonic-gate Elf32_Addr d_ptr; 59*0Sstevel@tonic-gate Elf32_Off d_off; 60*0Sstevel@tonic-gate } d_un; 61*0Sstevel@tonic-gate } Elf32_Dyn; 62*0Sstevel@tonic-gate 63*0Sstevel@tonic-gate #if defined(_LP64) || defined(_LONGLONG_TYPE) 64*0Sstevel@tonic-gate typedef struct { 65*0Sstevel@tonic-gate Elf64_Xword d_tag; /* how to interpret value */ 66*0Sstevel@tonic-gate union { 67*0Sstevel@tonic-gate Elf64_Xword d_val; 68*0Sstevel@tonic-gate Elf64_Addr d_ptr; 69*0Sstevel@tonic-gate } d_un; 70*0Sstevel@tonic-gate } Elf64_Dyn; 71*0Sstevel@tonic-gate #endif /* defined(_LP64) || defined(_LONGLONG_TYPE) */ 72*0Sstevel@tonic-gate #endif /* _ASM */ 73*0Sstevel@tonic-gate 74*0Sstevel@tonic-gate /* 75*0Sstevel@tonic-gate * Tag values 76*0Sstevel@tonic-gate */ 77*0Sstevel@tonic-gate #define DT_NULL 0 /* last entry in list */ 78*0Sstevel@tonic-gate #define DT_NEEDED 1 /* a needed object */ 79*0Sstevel@tonic-gate #define DT_PLTRELSZ 2 /* size of relocations for the PLT */ 80*0Sstevel@tonic-gate #define DT_PLTGOT 3 /* addresses used by procedure linkage table */ 81*0Sstevel@tonic-gate #define DT_HASH 4 /* hash table */ 82*0Sstevel@tonic-gate #define DT_STRTAB 5 /* string table */ 83*0Sstevel@tonic-gate #define DT_SYMTAB 6 /* symbol table */ 84*0Sstevel@tonic-gate #define DT_RELA 7 /* addr of relocation entries */ 85*0Sstevel@tonic-gate #define DT_RELASZ 8 /* size of relocation table */ 86*0Sstevel@tonic-gate #define DT_RELAENT 9 /* base size of relocation entry */ 87*0Sstevel@tonic-gate #define DT_STRSZ 10 /* size of string table */ 88*0Sstevel@tonic-gate #define DT_SYMENT 11 /* size of symbol table entry */ 89*0Sstevel@tonic-gate #define DT_INIT 12 /* _init addr */ 90*0Sstevel@tonic-gate #define DT_FINI 13 /* _fini addr */ 91*0Sstevel@tonic-gate #define DT_SONAME 14 /* name of this shared object */ 92*0Sstevel@tonic-gate #define DT_RPATH 15 /* run-time search path */ 93*0Sstevel@tonic-gate #define DT_SYMBOLIC 16 /* shared object linked -Bsymbolic */ 94*0Sstevel@tonic-gate #define DT_REL 17 /* addr of relocation entries */ 95*0Sstevel@tonic-gate #define DT_RELSZ 18 /* size of relocation table */ 96*0Sstevel@tonic-gate #define DT_RELENT 19 /* base size of relocation entry */ 97*0Sstevel@tonic-gate #define DT_PLTREL 20 /* relocation type for PLT entry */ 98*0Sstevel@tonic-gate #define DT_DEBUG 21 /* pointer to r_debug structure */ 99*0Sstevel@tonic-gate #define DT_TEXTREL 22 /* text relocations remain for this object */ 100*0Sstevel@tonic-gate #define DT_JMPREL 23 /* pointer to the PLT relocation entries */ 101*0Sstevel@tonic-gate #define DT_BIND_NOW 24 /* perform all relocations at load of object */ 102*0Sstevel@tonic-gate #define DT_INIT_ARRAY 25 /* pointer to .initarray */ 103*0Sstevel@tonic-gate #define DT_FINI_ARRAY 26 /* pointer to .finiarray */ 104*0Sstevel@tonic-gate #define DT_INIT_ARRAYSZ 27 /* size of .initarray */ 105*0Sstevel@tonic-gate #define DT_FINI_ARRAYSZ 28 /* size of .finiarray */ 106*0Sstevel@tonic-gate #define DT_RUNPATH 29 /* run-time search path */ 107*0Sstevel@tonic-gate #define DT_FLAGS 30 /* state flags - see DF_* */ 108*0Sstevel@tonic-gate 109*0Sstevel@tonic-gate #define DT_ENCODING 32 /* DT_* encoding rules start after this */ 110*0Sstevel@tonic-gate #define DT_PREINIT_ARRAY 32 /* pointer to .preinitarray segment */ 111*0Sstevel@tonic-gate #define DT_PREINIT_ARRAYSZ 33 /* size of .preinitarray segment */ 112*0Sstevel@tonic-gate 113*0Sstevel@tonic-gate #define DT_MAXPOSTAGS 34 /* number of positive tags */ 114*0Sstevel@tonic-gate 115*0Sstevel@tonic-gate #define DT_LOOS 0x6000000d /* OS specific range */ 116*0Sstevel@tonic-gate #define DT_SUNW_AUXILIARY 0x6000000d /* symbol auxiliary name */ 117*0Sstevel@tonic-gate #define DT_SUNW_RTLDINF 0x6000000e /* ld.so.1 info (private) */ 118*0Sstevel@tonic-gate #define DT_SUNW_FILTER 0x6000000f /* symbol filter name */ 119*0Sstevel@tonic-gate #define DT_SUNW_CAP 0x60000010 /* hardware/software */ 120*0Sstevel@tonic-gate /* capabilities */ 121*0Sstevel@tonic-gate #define DT_HIOS 0x6ffff000 122*0Sstevel@tonic-gate 123*0Sstevel@tonic-gate /* 124*0Sstevel@tonic-gate * The following values have been deprecated and remain here to allow 125*0Sstevel@tonic-gate * compatibility with older binaries. 126*0Sstevel@tonic-gate */ 127*0Sstevel@tonic-gate #define DT_DEPRECATED_SPARC_REGISTER 0x7000001 128*0Sstevel@tonic-gate 129*0Sstevel@tonic-gate /* 130*0Sstevel@tonic-gate * DT_* entries which fall between DT_VALRNGHI & DT_VALRNGLO use the 131*0Sstevel@tonic-gate * Dyn.d_un.d_val field of the Elf*_Dyn structure. 132*0Sstevel@tonic-gate */ 133*0Sstevel@tonic-gate #define DT_VALRNGLO 0x6ffffd00 134*0Sstevel@tonic-gate #define DT_CHECKSUM 0x6ffffdf8 /* elf checksum */ 135*0Sstevel@tonic-gate #define DT_PLTPADSZ 0x6ffffdf9 /* pltpadding size */ 136*0Sstevel@tonic-gate #define DT_MOVEENT 0x6ffffdfa /* move table entry size */ 137*0Sstevel@tonic-gate #define DT_MOVESZ 0x6ffffdfb /* move table size */ 138*0Sstevel@tonic-gate #define DT_FEATURE_1 0x6ffffdfc /* feature holder */ 139*0Sstevel@tonic-gate #define DT_POSFLAG_1 0x6ffffdfd /* flags for DT_* entries, effecting */ 140*0Sstevel@tonic-gate /* the following DT_* entry. */ 141*0Sstevel@tonic-gate /* See DF_P1_* definitions */ 142*0Sstevel@tonic-gate #define DT_SYMINSZ 0x6ffffdfe /* syminfo table size (in bytes) */ 143*0Sstevel@tonic-gate #define DT_SYMINENT 0x6ffffdff /* syminfo entry size (in bytes) */ 144*0Sstevel@tonic-gate #define DT_VALRNGHI 0x6ffffdff 145*0Sstevel@tonic-gate 146*0Sstevel@tonic-gate /* 147*0Sstevel@tonic-gate * DT_* entries which fall between DT_ADDRRNGHI & DT_ADDRRNGLO use the 148*0Sstevel@tonic-gate * Dyn.d_un.d_ptr field of the Elf*_Dyn structure. 149*0Sstevel@tonic-gate * 150*0Sstevel@tonic-gate * If any adjustment is made to the ELF object after it has been 151*0Sstevel@tonic-gate * built, these entries will need to be adjusted. 152*0Sstevel@tonic-gate */ 153*0Sstevel@tonic-gate #define DT_ADDRRNGLO 0x6ffffe00 154*0Sstevel@tonic-gate #define DT_CONFIG 0x6ffffefa /* configuration information */ 155*0Sstevel@tonic-gate #define DT_DEPAUDIT 0x6ffffefb /* dependency auditing */ 156*0Sstevel@tonic-gate #define DT_AUDIT 0x6ffffefc /* object auditing */ 157*0Sstevel@tonic-gate #define DT_PLTPAD 0x6ffffefd /* pltpadding (sparcv9) */ 158*0Sstevel@tonic-gate #define DT_MOVETAB 0x6ffffefe /* move table */ 159*0Sstevel@tonic-gate #define DT_SYMINFO 0x6ffffeff /* syminfo table */ 160*0Sstevel@tonic-gate #define DT_ADDRRNGHI 0x6ffffeff 161*0Sstevel@tonic-gate 162*0Sstevel@tonic-gate /* 163*0Sstevel@tonic-gate * The following DT_* entries should have been assigned within one of the 164*0Sstevel@tonic-gate * DT_* ranges, but existed before such ranges had been established. 165*0Sstevel@tonic-gate */ 166*0Sstevel@tonic-gate #define DT_VERSYM 0x6ffffff0 /* version symbol table - unused */ 167*0Sstevel@tonic-gate 168*0Sstevel@tonic-gate #define DT_RELACOUNT 0x6ffffff9 /* number of RELATIVE relocations */ 169*0Sstevel@tonic-gate #define DT_RELCOUNT 0x6ffffffa /* number of RELATIVE relocations */ 170*0Sstevel@tonic-gate #define DT_FLAGS_1 0x6ffffffb /* state flags - see DF_1_* defs */ 171*0Sstevel@tonic-gate #define DT_VERDEF 0x6ffffffc /* version definition table and */ 172*0Sstevel@tonic-gate #define DT_VERDEFNUM 0x6ffffffd /* associated no. of entries */ 173*0Sstevel@tonic-gate #define DT_VERNEED 0x6ffffffe /* version needed table and */ 174*0Sstevel@tonic-gate #define DT_VERNEEDNUM 0x6fffffff /* associated no. of entries */ 175*0Sstevel@tonic-gate 176*0Sstevel@tonic-gate /* 177*0Sstevel@tonic-gate * DT_* entries between DT_HIPROC and DT_LOPROC are reserved for processor 178*0Sstevel@tonic-gate * specific semantics. 179*0Sstevel@tonic-gate */ 180*0Sstevel@tonic-gate #define DT_LOPROC 0x70000000 /* processor specific range */ 181*0Sstevel@tonic-gate #define DT_AUXILIARY 0x7ffffffd /* shared library auxiliary name */ 182*0Sstevel@tonic-gate #define DT_USED 0x7ffffffe /* ignored - same as needed */ 183*0Sstevel@tonic-gate #define DT_FILTER 0x7fffffff /* shared library filter name */ 184*0Sstevel@tonic-gate #define DT_HIPROC 0x7fffffff 185*0Sstevel@tonic-gate 186*0Sstevel@tonic-gate 187*0Sstevel@tonic-gate /* 188*0Sstevel@tonic-gate * Values for DT_FLAGS 189*0Sstevel@tonic-gate */ 190*0Sstevel@tonic-gate #define DF_ORIGIN 0x00000001 /* ORIGIN processing required */ 191*0Sstevel@tonic-gate #define DF_SYMBOLIC 0x00000002 /* symbolic bindings in effect */ 192*0Sstevel@tonic-gate #define DF_TEXTREL 0x00000004 /* text relocations remain */ 193*0Sstevel@tonic-gate #define DF_BIND_NOW 0x00000008 /* process all relocations */ 194*0Sstevel@tonic-gate #define DF_STATIC_TLS 0x00000010 /* obj. contains static TLS refs */ 195*0Sstevel@tonic-gate 196*0Sstevel@tonic-gate /* 197*0Sstevel@tonic-gate * Values for the DT_POSFLAG_1 .dynamic entry. 198*0Sstevel@tonic-gate * These values only affect the following DT_* entry. 199*0Sstevel@tonic-gate */ 200*0Sstevel@tonic-gate #define DF_P1_LAZYLOAD 0x00000001 /* following object is to be */ 201*0Sstevel@tonic-gate /* lazy loaded */ 202*0Sstevel@tonic-gate #define DF_P1_GROUPPERM 0x00000002 /* following object's symbols are */ 203*0Sstevel@tonic-gate /* not available for general */ 204*0Sstevel@tonic-gate /* symbol bindings. */ 205*0Sstevel@tonic-gate /* 206*0Sstevel@tonic-gate * Values for the DT_FLAGS_1 .dynamic entry. 207*0Sstevel@tonic-gate */ 208*0Sstevel@tonic-gate #define DF_1_NOW 0x00000001 /* set RTLD_NOW for this object */ 209*0Sstevel@tonic-gate #define DF_1_GLOBAL 0x00000002 /* set RTLD_GLOBAL for this object */ 210*0Sstevel@tonic-gate #define DF_1_GROUP 0x00000004 /* set RTLD_GROUP for this object */ 211*0Sstevel@tonic-gate #define DF_1_NODELETE 0x00000008 /* set RTLD_NODELETE for this object */ 212*0Sstevel@tonic-gate #define DF_1_LOADFLTR 0x00000010 /* trigger filtee loading at runtime */ 213*0Sstevel@tonic-gate #define DF_1_INITFIRST 0x00000020 /* set RTLD_INITFIRST for this object */ 214*0Sstevel@tonic-gate #define DF_1_NOOPEN 0x00000040 /* set RTLD_NOOPEN for this object */ 215*0Sstevel@tonic-gate #define DF_1_ORIGIN 0x00000080 /* ORIGIN processing required */ 216*0Sstevel@tonic-gate #define DF_1_DIRECT 0x00000100 /* direct binding enabled */ 217*0Sstevel@tonic-gate #define DF_1_TRANS 0x00000200 218*0Sstevel@tonic-gate #define DF_1_INTERPOSE 0x00000400 /* object is an 'interposer' */ 219*0Sstevel@tonic-gate #define DF_1_NODEFLIB 0x00000800 /* ignore default library search path */ 220*0Sstevel@tonic-gate #define DF_1_NODUMP 0x00001000 /* object can't be dldump(3x)'ed */ 221*0Sstevel@tonic-gate #define DF_1_CONFALT 0x00002000 /* configuration alternative created */ 222*0Sstevel@tonic-gate #define DF_1_ENDFILTEE 0x00004000 /* filtee terminates filters search */ 223*0Sstevel@tonic-gate #define DF_1_DISPRELDNE 0x00008000 /* disp reloc applied at build time */ 224*0Sstevel@tonic-gate #define DF_1_DISPRELPND 0x00010000 /* disp reloc applied at run-time */ 225*0Sstevel@tonic-gate #define DF_1_NODIRECT 0x00020000 /* object contains symbols that */ 226*0Sstevel@tonic-gate /* cannot be directly bound to */ 227*0Sstevel@tonic-gate #define DF_1_IGNMULDEF 0x00040000 /* krtld link should muldef'd syms */ 228*0Sstevel@tonic-gate #define DF_1_NOKSYMS 0x00080000 /* object's symbols should not be */ 229*0Sstevel@tonic-gate /* exported via /dev/ksyms */ 230*0Sstevel@tonic-gate #define DF_1_NORELOC 0x00400000 231*0Sstevel@tonic-gate 232*0Sstevel@tonic-gate /* 233*0Sstevel@tonic-gate * Values set to DT_FEATURE tag's d_val. 234*0Sstevel@tonic-gate */ 235*0Sstevel@tonic-gate #define DTF_1_PARINIT 0x00000001 /* partially initialization feature */ 236*0Sstevel@tonic-gate #define DTF_1_CONFEXP 0x00000002 /* configuration file expected */ 237*0Sstevel@tonic-gate 238*0Sstevel@tonic-gate 239*0Sstevel@tonic-gate /* 240*0Sstevel@tonic-gate * Version structures. There are three types of version structure: 241*0Sstevel@tonic-gate * 242*0Sstevel@tonic-gate * o A definition of the versions within the image itself. 243*0Sstevel@tonic-gate * Each version definition is assigned a unique index (starting from 244*0Sstevel@tonic-gate * VER_NDX_BGNDEF) which is used to cross-reference symbols associated to 245*0Sstevel@tonic-gate * the version. Each version can have one or more dependencies on other 246*0Sstevel@tonic-gate * version definitions within the image. The version name, and any 247*0Sstevel@tonic-gate * dependency names, are specified in the version definition auxiliary 248*0Sstevel@tonic-gate * array. Version definition entries require a version symbol index table. 249*0Sstevel@tonic-gate * 250*0Sstevel@tonic-gate * o A version requirement on a needed dependency. Each needed entry 251*0Sstevel@tonic-gate * specifies the shared object dependency (as specified in DT_NEEDED). 252*0Sstevel@tonic-gate * One or more versions required from this dependency are specified in the 253*0Sstevel@tonic-gate * version needed auxiliary array. 254*0Sstevel@tonic-gate * 255*0Sstevel@tonic-gate * o A version symbol index table. Each symbol indexes into this array 256*0Sstevel@tonic-gate * to determine its version index. Index values of VER_NDX_BGNDEF or 257*0Sstevel@tonic-gate * greater indicate the version definition to which a symbol is associated. 258*0Sstevel@tonic-gate * (the size of a symbol index entry is recorded in the sh_info field). 259*0Sstevel@tonic-gate */ 260*0Sstevel@tonic-gate #ifndef _ASM 261*0Sstevel@tonic-gate 262*0Sstevel@tonic-gate typedef struct { /* Version Definition Structure. */ 263*0Sstevel@tonic-gate Elf32_Half vd_version; /* this structures version revision */ 264*0Sstevel@tonic-gate Elf32_Half vd_flags; /* version information */ 265*0Sstevel@tonic-gate Elf32_Half vd_ndx; /* version index */ 266*0Sstevel@tonic-gate Elf32_Half vd_cnt; /* no. of associated aux entries */ 267*0Sstevel@tonic-gate Elf32_Word vd_hash; /* version name hash value */ 268*0Sstevel@tonic-gate Elf32_Word vd_aux; /* no. of bytes from start of this */ 269*0Sstevel@tonic-gate /* verdef to verdaux array */ 270*0Sstevel@tonic-gate Elf32_Word vd_next; /* no. of bytes from start of this */ 271*0Sstevel@tonic-gate } Elf32_Verdef; /* verdef to next verdef entry */ 272*0Sstevel@tonic-gate 273*0Sstevel@tonic-gate typedef struct { /* Verdef Auxiliary Structure. */ 274*0Sstevel@tonic-gate Elf32_Word vda_name; /* first element defines the version */ 275*0Sstevel@tonic-gate /* name. Additional entries */ 276*0Sstevel@tonic-gate /* define dependency names. */ 277*0Sstevel@tonic-gate Elf32_Word vda_next; /* no. of bytes from start of this */ 278*0Sstevel@tonic-gate } Elf32_Verdaux; /* verdaux to next verdaux entry */ 279*0Sstevel@tonic-gate 280*0Sstevel@tonic-gate 281*0Sstevel@tonic-gate typedef struct { /* Version Requirement Structure. */ 282*0Sstevel@tonic-gate Elf32_Half vn_version; /* this structures version revision */ 283*0Sstevel@tonic-gate Elf32_Half vn_cnt; /* no. of associated aux entries */ 284*0Sstevel@tonic-gate Elf32_Word vn_file; /* name of needed dependency (file) */ 285*0Sstevel@tonic-gate Elf32_Word vn_aux; /* no. of bytes from start of this */ 286*0Sstevel@tonic-gate /* verneed to vernaux array */ 287*0Sstevel@tonic-gate Elf32_Word vn_next; /* no. of bytes from start of this */ 288*0Sstevel@tonic-gate } Elf32_Verneed; /* verneed to next verneed entry */ 289*0Sstevel@tonic-gate 290*0Sstevel@tonic-gate typedef struct { /* Verneed Auxiliary Structure. */ 291*0Sstevel@tonic-gate Elf32_Word vna_hash; /* version name hash value */ 292*0Sstevel@tonic-gate Elf32_Half vna_flags; /* version information */ 293*0Sstevel@tonic-gate Elf32_Half vna_other; 294*0Sstevel@tonic-gate Elf32_Word vna_name; /* version name */ 295*0Sstevel@tonic-gate Elf32_Word vna_next; /* no. of bytes from start of this */ 296*0Sstevel@tonic-gate } Elf32_Vernaux; /* vernaux to next vernaux entry */ 297*0Sstevel@tonic-gate 298*0Sstevel@tonic-gate typedef Elf32_Half Elf32_Versym; /* Version symbol index array */ 299*0Sstevel@tonic-gate 300*0Sstevel@tonic-gate typedef struct { 301*0Sstevel@tonic-gate Elf32_Half si_boundto; /* direct bindings - symbol bound to */ 302*0Sstevel@tonic-gate Elf32_Half si_flags; /* per symbol flags */ 303*0Sstevel@tonic-gate } Elf32_Syminfo; 304*0Sstevel@tonic-gate 305*0Sstevel@tonic-gate 306*0Sstevel@tonic-gate #if defined(_LP64) || defined(_LONGLONG_TYPE) 307*0Sstevel@tonic-gate typedef struct { 308*0Sstevel@tonic-gate Elf64_Half vd_version; /* this structures version revision */ 309*0Sstevel@tonic-gate Elf64_Half vd_flags; /* version information */ 310*0Sstevel@tonic-gate Elf64_Half vd_ndx; /* version index */ 311*0Sstevel@tonic-gate Elf64_Half vd_cnt; /* no. of associated aux entries */ 312*0Sstevel@tonic-gate Elf64_Word vd_hash; /* version name hash value */ 313*0Sstevel@tonic-gate Elf64_Word vd_aux; /* no. of bytes from start of this */ 314*0Sstevel@tonic-gate /* verdef to verdaux array */ 315*0Sstevel@tonic-gate Elf64_Word vd_next; /* no. of bytes from start of this */ 316*0Sstevel@tonic-gate } Elf64_Verdef; /* verdef to next verdef entry */ 317*0Sstevel@tonic-gate 318*0Sstevel@tonic-gate typedef struct { 319*0Sstevel@tonic-gate Elf64_Word vda_name; /* first element defines the version */ 320*0Sstevel@tonic-gate /* name. Additional entries */ 321*0Sstevel@tonic-gate /* define dependency names. */ 322*0Sstevel@tonic-gate Elf64_Word vda_next; /* no. of bytes from start of this */ 323*0Sstevel@tonic-gate } Elf64_Verdaux; /* verdaux to next verdaux entry */ 324*0Sstevel@tonic-gate 325*0Sstevel@tonic-gate typedef struct { 326*0Sstevel@tonic-gate Elf64_Half vn_version; /* this structures version revision */ 327*0Sstevel@tonic-gate Elf64_Half vn_cnt; /* no. of associated aux entries */ 328*0Sstevel@tonic-gate Elf64_Word vn_file; /* name of needed dependency (file) */ 329*0Sstevel@tonic-gate Elf64_Word vn_aux; /* no. of bytes from start of this */ 330*0Sstevel@tonic-gate /* verneed to vernaux array */ 331*0Sstevel@tonic-gate Elf64_Word vn_next; /* no. of bytes from start of this */ 332*0Sstevel@tonic-gate } Elf64_Verneed; /* verneed to next verneed entry */ 333*0Sstevel@tonic-gate 334*0Sstevel@tonic-gate typedef struct { 335*0Sstevel@tonic-gate Elf64_Word vna_hash; /* version name hash value */ 336*0Sstevel@tonic-gate Elf64_Half vna_flags; /* version information */ 337*0Sstevel@tonic-gate Elf64_Half vna_other; 338*0Sstevel@tonic-gate Elf64_Word vna_name; /* version name */ 339*0Sstevel@tonic-gate Elf64_Word vna_next; /* no. of bytes from start of this */ 340*0Sstevel@tonic-gate } Elf64_Vernaux; /* vernaux to next vernaux entry */ 341*0Sstevel@tonic-gate 342*0Sstevel@tonic-gate typedef Elf64_Half Elf64_Versym; 343*0Sstevel@tonic-gate 344*0Sstevel@tonic-gate typedef struct { 345*0Sstevel@tonic-gate Elf64_Half si_boundto; /* direct bindings - symbol bound to */ 346*0Sstevel@tonic-gate Elf64_Half si_flags; /* per symbol flags */ 347*0Sstevel@tonic-gate } Elf64_Syminfo; 348*0Sstevel@tonic-gate #endif /* defined(_LP64) || defined(_LONGLONG_TYPE) */ 349*0Sstevel@tonic-gate 350*0Sstevel@tonic-gate #endif /* _ASM */ 351*0Sstevel@tonic-gate 352*0Sstevel@tonic-gate /* 353*0Sstevel@tonic-gate * Versym symbol index values. Values greater than VER_NDX_GLOBAL 354*0Sstevel@tonic-gate * and less then VER_NDX_LORESERVE associate symbols with user 355*0Sstevel@tonic-gate * specified version descriptors. 356*0Sstevel@tonic-gate */ 357*0Sstevel@tonic-gate #define VER_NDX_LOCAL 0 /* symbol is local */ 358*0Sstevel@tonic-gate #define VER_NDX_GLOBAL 1 /* symbol is global and assigned to */ 359*0Sstevel@tonic-gate /* the base version */ 360*0Sstevel@tonic-gate #define VER_NDX_LORESERVE 0xff00 /* beginning of RESERVED entries */ 361*0Sstevel@tonic-gate #define VER_NDX_ELIMINATE 0xff01 /* symbol is to be eliminated */ 362*0Sstevel@tonic-gate 363*0Sstevel@tonic-gate /* 364*0Sstevel@tonic-gate * Verdef and Verneed (via Veraux) flags values. 365*0Sstevel@tonic-gate */ 366*0Sstevel@tonic-gate #define VER_FLG_BASE 0x1 /* version definition of file itself */ 367*0Sstevel@tonic-gate #define VER_FLG_WEAK 0x2 /* weak version identifier */ 368*0Sstevel@tonic-gate 369*0Sstevel@tonic-gate /* 370*0Sstevel@tonic-gate * Verdef version values. 371*0Sstevel@tonic-gate */ 372*0Sstevel@tonic-gate #define VER_DEF_NONE 0 /* Ver_def version */ 373*0Sstevel@tonic-gate #define VER_DEF_CURRENT 1 374*0Sstevel@tonic-gate #define VER_DEF_NUM 2 375*0Sstevel@tonic-gate 376*0Sstevel@tonic-gate /* 377*0Sstevel@tonic-gate * Verneed version values. 378*0Sstevel@tonic-gate */ 379*0Sstevel@tonic-gate #define VER_NEED_NONE 0 /* Ver_need version */ 380*0Sstevel@tonic-gate #define VER_NEED_CURRENT 1 381*0Sstevel@tonic-gate #define VER_NEED_NUM 2 382*0Sstevel@tonic-gate 383*0Sstevel@tonic-gate 384*0Sstevel@tonic-gate /* 385*0Sstevel@tonic-gate * Syminfo flag values 386*0Sstevel@tonic-gate */ 387*0Sstevel@tonic-gate #define SYMINFO_FLG_DIRECT 0x0001 /* symbol ref has direct association */ 388*0Sstevel@tonic-gate /* to object containing defn. */ 389*0Sstevel@tonic-gate #define SYMINFO_FLG_PASSTHRU 0x0002 /* ignored - see SYMINFO_FLG_FILTER */ 390*0Sstevel@tonic-gate #define SYMINFO_FLG_COPY 0x0004 /* symbol is a copy-reloc */ 391*0Sstevel@tonic-gate #define SYMINFO_FLG_LAZYLOAD 0x0008 /* object containing defn should be */ 392*0Sstevel@tonic-gate /* lazily-loaded */ 393*0Sstevel@tonic-gate #define SYMINFO_FLG_DIRECTBIND 0x0010 /* ref should be bound directly to */ 394*0Sstevel@tonic-gate /* object containing defn. */ 395*0Sstevel@tonic-gate #define SYMINFO_FLG_NOEXTDIRECT 0x0020 /* don't let an external reference */ 396*0Sstevel@tonic-gate /* directly bind to this symbol */ 397*0Sstevel@tonic-gate #define SYMINFO_FLG_FILTER 0x0002 /* symbol ref is associated to a */ 398*0Sstevel@tonic-gate #define SYMINFO_FLG_AUXILIARY 0x0040 /* standard or auxiliary filter */ 399*0Sstevel@tonic-gate 400*0Sstevel@tonic-gate /* 401*0Sstevel@tonic-gate * Syminfo.si_boundto values. 402*0Sstevel@tonic-gate */ 403*0Sstevel@tonic-gate #define SYMINFO_BT_SELF 0xffff /* symbol bound to self */ 404*0Sstevel@tonic-gate #define SYMINFO_BT_PARENT 0xfffe /* symbol bound to parent */ 405*0Sstevel@tonic-gate #define SYMINFO_BT_NONE 0xfffd /* no special symbol binding */ 406*0Sstevel@tonic-gate #define SYMINFO_BT_EXTERN 0xfffc /* symbol defined as external */ 407*0Sstevel@tonic-gate #define SYMINFO_BT_LOWRESERVE 0xff00 /* beginning of reserved entries */ 408*0Sstevel@tonic-gate 409*0Sstevel@tonic-gate /* 410*0Sstevel@tonic-gate * Syminfo version values. 411*0Sstevel@tonic-gate */ 412*0Sstevel@tonic-gate #define SYMINFO_NONE 0 /* Syminfo version */ 413*0Sstevel@tonic-gate #define SYMINFO_CURRENT 1 414*0Sstevel@tonic-gate #define SYMINFO_NUM 2 415*0Sstevel@tonic-gate 416*0Sstevel@tonic-gate 417*0Sstevel@tonic-gate /* 418*0Sstevel@tonic-gate * Public structure defined and maintained within the runtime linker 419*0Sstevel@tonic-gate */ 420*0Sstevel@tonic-gate #ifndef _ASM 421*0Sstevel@tonic-gate 422*0Sstevel@tonic-gate typedef struct link_map Link_map; 423*0Sstevel@tonic-gate 424*0Sstevel@tonic-gate struct link_map { 425*0Sstevel@tonic-gate unsigned long l_addr; /* address at which object is mapped */ 426*0Sstevel@tonic-gate char *l_name; /* full name of loaded object */ 427*0Sstevel@tonic-gate #ifdef _LP64 428*0Sstevel@tonic-gate Elf64_Dyn *l_ld; /* dynamic structure of object */ 429*0Sstevel@tonic-gate #else 430*0Sstevel@tonic-gate Elf32_Dyn *l_ld; /* dynamic structure of object */ 431*0Sstevel@tonic-gate #endif 432*0Sstevel@tonic-gate Link_map *l_next; /* next link object */ 433*0Sstevel@tonic-gate Link_map *l_prev; /* previous link object */ 434*0Sstevel@tonic-gate char *l_refname; /* filters reference name */ 435*0Sstevel@tonic-gate }; 436*0Sstevel@tonic-gate 437*0Sstevel@tonic-gate #ifdef _SYSCALL32 438*0Sstevel@tonic-gate typedef struct link_map32 Link_map32; 439*0Sstevel@tonic-gate 440*0Sstevel@tonic-gate struct link_map32 { 441*0Sstevel@tonic-gate Elf32_Word l_addr; 442*0Sstevel@tonic-gate Elf32_Addr l_name; 443*0Sstevel@tonic-gate Elf32_Addr l_ld; 444*0Sstevel@tonic-gate Elf32_Addr l_next; 445*0Sstevel@tonic-gate Elf32_Addr l_prev; 446*0Sstevel@tonic-gate Elf32_Addr l_refname; 447*0Sstevel@tonic-gate }; 448*0Sstevel@tonic-gate #endif 449*0Sstevel@tonic-gate 450*0Sstevel@tonic-gate typedef enum { 451*0Sstevel@tonic-gate RT_CONSISTENT, 452*0Sstevel@tonic-gate RT_ADD, 453*0Sstevel@tonic-gate RT_DELETE 454*0Sstevel@tonic-gate } r_state_e; 455*0Sstevel@tonic-gate 456*0Sstevel@tonic-gate typedef enum { 457*0Sstevel@tonic-gate RD_FL_NONE = 0, /* no flags */ 458*0Sstevel@tonic-gate RD_FL_ODBG = (1<<0), /* old style debugger present */ 459*0Sstevel@tonic-gate RD_FL_DBG = (1<<1) /* debugging enabled */ 460*0Sstevel@tonic-gate } rd_flags_e; 461*0Sstevel@tonic-gate 462*0Sstevel@tonic-gate 463*0Sstevel@tonic-gate 464*0Sstevel@tonic-gate /* 465*0Sstevel@tonic-gate * Debugging events enabled inside of the runtime linker. To 466*0Sstevel@tonic-gate * access these events see the librtld_db interface. 467*0Sstevel@tonic-gate */ 468*0Sstevel@tonic-gate typedef enum { 469*0Sstevel@tonic-gate RD_NONE = 0, /* no event */ 470*0Sstevel@tonic-gate RD_PREINIT, /* the Initial rendezvous before .init */ 471*0Sstevel@tonic-gate RD_POSTINIT, /* the Second rendezvous after .init */ 472*0Sstevel@tonic-gate RD_DLACTIVITY /* a dlopen or dlclose has happened */ 473*0Sstevel@tonic-gate } rd_event_e; 474*0Sstevel@tonic-gate 475*0Sstevel@tonic-gate struct r_debug { 476*0Sstevel@tonic-gate int r_version; /* debugging info version no. */ 477*0Sstevel@tonic-gate Link_map *r_map; /* address of link_map */ 478*0Sstevel@tonic-gate unsigned long r_brk; /* address of update routine */ 479*0Sstevel@tonic-gate r_state_e r_state; 480*0Sstevel@tonic-gate unsigned long r_ldbase; /* base addr of ld.so */ 481*0Sstevel@tonic-gate Link_map *r_ldsomap; /* address of ld.so.1's link map */ 482*0Sstevel@tonic-gate rd_event_e r_rdevent; /* debug event */ 483*0Sstevel@tonic-gate rd_flags_e r_flags; /* misc flags. */ 484*0Sstevel@tonic-gate }; 485*0Sstevel@tonic-gate 486*0Sstevel@tonic-gate #ifdef _SYSCALL32 487*0Sstevel@tonic-gate struct r_debug32 { 488*0Sstevel@tonic-gate Elf32_Word r_version; /* debugging info version no. */ 489*0Sstevel@tonic-gate Elf32_Addr r_map; /* address of link_map */ 490*0Sstevel@tonic-gate Elf32_Word r_brk; /* address of update routine */ 491*0Sstevel@tonic-gate r_state_e r_state; 492*0Sstevel@tonic-gate Elf32_Word r_ldbase; /* base addr of ld.so */ 493*0Sstevel@tonic-gate Elf32_Addr r_ldsomap; /* address of ld.so.1's link map */ 494*0Sstevel@tonic-gate rd_event_e r_rdevent; /* debug event */ 495*0Sstevel@tonic-gate rd_flags_e r_flags; /* misc flags. */ 496*0Sstevel@tonic-gate }; 497*0Sstevel@tonic-gate #endif 498*0Sstevel@tonic-gate 499*0Sstevel@tonic-gate 500*0Sstevel@tonic-gate #define R_DEBUG_VERSION 2 /* current r_debug version */ 501*0Sstevel@tonic-gate #endif /* _ASM */ 502*0Sstevel@tonic-gate 503*0Sstevel@tonic-gate /* 504*0Sstevel@tonic-gate * Attribute/value structures used to bootstrap ELF-based dynamic linker. 505*0Sstevel@tonic-gate */ 506*0Sstevel@tonic-gate #ifndef _ASM 507*0Sstevel@tonic-gate typedef struct { 508*0Sstevel@tonic-gate Elf32_Sword eb_tag; /* what this one is */ 509*0Sstevel@tonic-gate union { /* possible values */ 510*0Sstevel@tonic-gate Elf32_Word eb_val; 511*0Sstevel@tonic-gate Elf32_Addr eb_ptr; 512*0Sstevel@tonic-gate Elf32_Off eb_off; 513*0Sstevel@tonic-gate } eb_un; 514*0Sstevel@tonic-gate } Elf32_Boot; 515*0Sstevel@tonic-gate 516*0Sstevel@tonic-gate #if defined(_LP64) || defined(_LONGLONG_TYPE) 517*0Sstevel@tonic-gate typedef struct { 518*0Sstevel@tonic-gate Elf64_Xword eb_tag; /* what this one is */ 519*0Sstevel@tonic-gate union { /* possible values */ 520*0Sstevel@tonic-gate Elf64_Xword eb_val; 521*0Sstevel@tonic-gate Elf64_Addr eb_ptr; 522*0Sstevel@tonic-gate Elf64_Off eb_off; 523*0Sstevel@tonic-gate } eb_un; 524*0Sstevel@tonic-gate } Elf64_Boot; 525*0Sstevel@tonic-gate #endif /* defined(_LP64) || defined(_LONGLONG_TYPE) */ 526*0Sstevel@tonic-gate #endif /* _ASM */ 527*0Sstevel@tonic-gate 528*0Sstevel@tonic-gate /* 529*0Sstevel@tonic-gate * Attributes 530*0Sstevel@tonic-gate */ 531*0Sstevel@tonic-gate #define EB_NULL 0 /* (void) last entry */ 532*0Sstevel@tonic-gate #define EB_DYNAMIC 1 /* (*) dynamic structure of subject */ 533*0Sstevel@tonic-gate #define EB_LDSO_BASE 2 /* (caddr_t) base address of ld.so */ 534*0Sstevel@tonic-gate #define EB_ARGV 3 /* (caddr_t) argument vector */ 535*0Sstevel@tonic-gate #define EB_ENVP 4 /* (char **) environment strings */ 536*0Sstevel@tonic-gate #define EB_AUXV 5 /* (auxv_t *) auxiliary vector */ 537*0Sstevel@tonic-gate #define EB_DEVZERO 6 /* (int) fd for /dev/zero */ 538*0Sstevel@tonic-gate #define EB_PAGESIZE 7 /* (int) page size */ 539*0Sstevel@tonic-gate #define EB_MAX 8 /* number of "EBs" */ 540*0Sstevel@tonic-gate #define EB_MAX_SIZE32 64 /* size in bytes, _ILP32 */ 541*0Sstevel@tonic-gate #define EB_MAX_SIZE64 128 /* size in bytes, _LP64 */ 542*0Sstevel@tonic-gate 543*0Sstevel@tonic-gate 544*0Sstevel@tonic-gate #ifndef _ASM 545*0Sstevel@tonic-gate 546*0Sstevel@tonic-gate #ifdef __STDC__ 547*0Sstevel@tonic-gate 548*0Sstevel@tonic-gate /* 549*0Sstevel@tonic-gate * Concurrency communication structure for libc callbacks. 550*0Sstevel@tonic-gate */ 551*0Sstevel@tonic-gate extern void _ld_libc(void *); 552*0Sstevel@tonic-gate #else /* __STDC__ */ 553*0Sstevel@tonic-gate extern void _ld_libc(); 554*0Sstevel@tonic-gate #endif /* __STDC__ */ 555*0Sstevel@tonic-gate 556*0Sstevel@tonic-gate #pragma unknown_control_flow(_ld_libc) 557*0Sstevel@tonic-gate #endif /* _ASM */ 558*0Sstevel@tonic-gate 559*0Sstevel@tonic-gate #ifdef __cplusplus 560*0Sstevel@tonic-gate } 561*0Sstevel@tonic-gate #endif 562*0Sstevel@tonic-gate 563*0Sstevel@tonic-gate #endif /* _SYS_LINK_H */ 564