conv.h revision 2352:9cdfed81bb1c
1/*
2 * CDDL HEADER START
3 *
4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
7 *
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
12 *
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
18 *
19 * CDDL HEADER END
20 */
21
22/*
23 *	Copyright (c) 1988 AT&T
24 *	  All Rights Reserved
25 *
26 * Copyright 2006 Sun Microsystems, Inc.  All rights reserved.
27 * Use is subject to license terms.
28 */
29
30#ifndef	_CONV_H
31#define	_CONV_H
32
33#pragma ident	"%Z%%M%	%I%	%E% SMI"
34
35/*
36 * Global include file for conversion library.
37 */
38
39#include <stdlib.h>
40#include <libelf.h>
41#include <dlfcn.h>
42#include <libld.h>
43#include <sgs.h>
44#include <machdep.h>
45
46#ifdef	__cplusplus
47extern "C" {
48#endif
49
50/*
51 * Configuration features available - maintained here (instead of debug.h)
52 * to save libconv from having to include debug.h which results in numerous
53 * "declared but not used or defined" lint errors.
54 */
55#define	CONF_EDLIBPATH	0x000100	/* ELF default library path */
56#define	CONF_ESLIBPATH	0x000200	/* ELF secure library path */
57#define	CONF_ADLIBPATH	0x000400	/* AOUT default library path */
58#define	CONF_ASLIBPATH	0x000800	/* AOUT secure library path */
59#define	CONF_DIRCFG	0x001000	/* directory configuration available */
60#define	CONF_OBJALT	0x002000	/* object alternatives available */
61#define	CONF_MEMRESV	0x004000	/* memory reservation required */
62#define	CONF_ENVS	0x008000	/* environment variables available */
63#define	CONF_FLTR	0x010000	/* filter information available */
64#define	CONF_FEATMSK	0xffff00
65
66/*
67 * Various values that can't be matched to a symbolic definition are converted
68 * to a numeric string.  Each function that may require this fallback maintains
69 * its own static string buffer, as many conversion routines may be called for
70 * one final diagnostic.  See conv_invalid_val().
71 *
72 * The string size reflects the largest possible decimal number plus a trailing
73 * null.  Typically however, values are hex with a leading "0x".
74 */
75#if	defined(_ELF64)
76#define	CONV_INV_STRSIZE	22
77#else
78#define	CONV_INV_STRSIZE	12
79#endif
80
81/*
82 * Flags that alter standard formatting for conversion routines.
83 */
84#define	CONV_FMT_DECIMAL	0x01	/* conv_invalid_val() should print */
85					/*    integer print as decimal */
86					/*    (default is hex) */
87#define	CONV_FMT_SPACE		0x02	/* conv_invalid_val() should append */
88					/*    a space after the number.  */
89#define	CONV_FMT_ALTDUMP	0x04	/* Output strings using the versions */
90					/*    used by the dump program. */
91#define	CONV_FMT_ALTFILE	0x08	/* Output strings in the form used */
92					/*    by the file(1) command */
93#define	CONV_FMT_ALTCRLE	0x10	/* Output strings in the form used */
94					/*    by the crle(1) command */
95
96/*
97 * Mask of CONV_FMT bits that reflect a desire to use alternate strings.
98 */
99#define	CONV_FMTALTMASK (CONV_FMT_ALTDUMP|CONV_FMT_ALTFILE)
100
101/*
102 * The expansion of bit-field data items is driven from a value descriptor and
103 * the conv_expn_field() routine.
104 */
105typedef struct {
106	Xword		v_val;		/* expansion value */
107	const char	*v_msg;		/* associated message string */
108} Val_desc;
109
110/*
111 * conv_expn_field() is willing to supply default strings for the
112 * prefix, separator, and suffix arguments, if they are passed as NULL.
113 * The caller needs to know how much room to allow for these items.
114 * These values supply those sizes.
115 */
116#define	CONV_EXPN_FIELD_DEF_PREFIX_SIZE	2	/* Default is "[ " */
117#define	CONV_EXPN_FIELD_DEF_SEP_SIZE	1	/* Default is " " */
118#define	CONV_EXPN_FIELD_DEF_SUFFIX_SIZE	2	/* Default is " ]" */
119
120
121/*
122 * conv_expn_field() requires a large number of inputs, many of which
123 * can be NULL to accept default behavior. An argument of the following
124 * type is used to supply them.
125 */
126typedef struct {
127	char *buf;		/* Buffer to receive generated string */
128	size_t bufsize;		/* sizeof(buf) */
129	const Val_desc *vdp;	/* Array of value descriptors, giving the */
130				/*	possible bit values, and their */
131				/*	corresponding strings. Note that the */
132				/*	final element must contain only NULL */
133				/*	values. This terminates the list. */
134	const char **lead_str;	/* NULL, or array of pointers to strings to */
135				/*	be output at the head of the list. */
136				/*	Last entry must be NULL. */
137	Xword oflags;		/* Bits for which output strings are desired */
138	Xword rflags;		/* Bits for which a numeric value should be */
139				/*	output if vdp does not provide str. */
140				/*	Must be a proper subset of oflags */
141	const char *prefix;	/* NULL, or string to prefix output with */
142				/*	If NULL, "[ " is used. */
143	const char *sep;	/* NULL, or string to separate output items */
144				/*	with. If NULL, " " is used. */
145	const char *suffix;	/* NULL, or string to suffix output with */
146				/*	If NULL, " ]" is used. */
147} CONV_EXPN_FIELD_ARG;
148
149
150/*
151 * Define all generic interfaces.
152 */
153extern	void		conv_check_native(char **, char **);
154extern	const char	*conv_config_feat(int);
155extern	const char	*conv_config_obj(ushort_t);
156extern	const char	*conv_config_upm(const char *, const char *,
157			    const char *, size_t);
158extern	const char	*conv_def_tag(Symref);
159extern	const char	*conv_demangle_name(const char *);
160extern	const char	*conv_dl_flag(int, int);
161extern	const char	*conv_dl_mode(int, int);
162extern	const char	*conv_dwarf_ehe(uint_t);
163extern	const char	*conv_elfdata_type(Elf_Type);
164extern	const char	*conv_grphdl_flags(uint_t);
165extern	Isa_desc	*conv_isalist(void);
166extern	const char	*conv_lddstub(int);
167extern	const char	*conv_seg_flags(Half);
168extern	int		conv_sys_eclass();
169extern	Uts_desc	*conv_uts(void);
170extern	const char	*conv_ver_flags(Half);
171
172/*
173 * Define all class specific routines.
174 */
175#if	defined(_ELF64)
176#define	conv_bnd_obj		conv64_bnd_obj
177#define	conv_bnd_type		conv64_bnd_type
178#define	conv_cap_tag		conv64_cap_tag
179#define	conv_cap_val		conv64_cap_val
180#define	conv_cap_val_hw1	conv64_cap_val_hw1
181#define	conv_cap_val_sf1	conv64_cap_val_sf1
182#define	conv_dyn_feature1	conv64_dyn_feature1
183#define	conv_dyn_flag1		conv64_dyn_flag1
184#define	conv_dyn_flag		conv64_dyn_flag
185#define	conv_dyn_posflag1	conv64_dyn_posflag1
186#define	conv_dyn_tag		conv64_dyn_tag
187#define	conv_ehdr_class		conv64_ehdr_class
188#define	conv_ehdr_data		conv64_ehdr_data
189#define	conv_ehdr_flags		conv64_ehdr_flags
190#define	conv_ehdr_mach		conv64_ehdr_mach
191#define	conv_ehdr_type		conv64_ehdr_type
192#define	conv_ehdr_vers		conv64_ehdr_vers
193#define	conv_expn_field		conv64_expn_field
194#define	conv_invalid_val	conv64_invalid_val
195#define	conv_phdr_flags		conv64_phdr_flags
196#define	conv_phdr_type		conv64_phdr_type
197#define	conv_reject_desc	conv64_reject_desc
198#define	conv_reloc_type		conv64_reloc_type
199#define	conv_reloc_386_type	conv64_reloc_386_type
200#define	conv_reloc_amd64_type	conv64_reloc_amd64_type
201#define	conv_reloc_SPARC_type	conv64_reloc_SPARC_type
202#define	conv_sec_flags		conv64_sec_flags
203#define	conv_sec_info		conv64_sec_info
204#define	conv_sec_type		conv64_sec_type
205#define	conv_sym_info_bind	conv64_sym_info_bind
206#define	conv_sym_info_type	conv64_sym_info_type
207#define	conv_sym_shndx		conv64_sym_shndx
208#define	conv_sym_other		conv64_sym_other
209#define	conv_sym_value		conv64_sym_value
210#define	conv_sym_SPARC_value	conv64_sym_SPARC_value
211#else
212#define	conv_bnd_obj		conv32_bnd_obj
213#define	conv_bnd_type		conv32_bnd_type
214#define	conv_cap_tag		conv32_cap_tag
215#define	conv_cap_val		conv32_cap_val
216#define	conv_cap_val_hw1	conv32_cap_val_hw1
217#define	conv_cap_val_sf1	conv32_cap_val_sf1
218#define	conv_dyn_feature1	conv32_dyn_feature1
219#define	conv_dyn_flag1		conv32_dyn_flag1
220#define	conv_dyn_flag		conv32_dyn_flag
221#define	conv_dyn_posflag1	conv32_dyn_posflag1
222#define	conv_dyn_tag		conv32_dyn_tag
223#define	conv_ehdr_class		conv32_ehdr_class
224#define	conv_ehdr_data		conv32_ehdr_data
225#define	conv_ehdr_flags		conv32_ehdr_flags
226#define	conv_ehdr_mach		conv32_ehdr_mach
227#define	conv_ehdr_type		conv32_ehdr_type
228#define	conv_ehdr_vers		conv32_ehdr_vers
229#define	conv_expn_field		conv32_expn_field
230#define	conv_invalid_val	conv32_invalid_val
231#define	conv_phdr_flags		conv32_phdr_flags
232#define	conv_phdr_type		conv32_phdr_type
233#define	conv_reject_desc	conv32_reject_desc
234#define	conv_reloc_type		conv32_reloc_type
235#define	conv_reloc_386_type	conv32_reloc_386_type
236#define	conv_reloc_amd64_type	conv32_reloc_amd64_type
237#define	conv_reloc_SPARC_type	conv32_reloc_SPARC_type
238#define	conv_sec_flags		conv32_sec_flags
239#define	conv_sec_info		conv32_sec_info
240#define	conv_sec_type		conv32_sec_type
241#define	conv_sym_info_bind	conv32_sym_info_bind
242#define	conv_sym_info_type	conv32_sym_info_type
243#define	conv_sym_shndx		conv32_sym_shndx
244#define	conv_sym_other		conv32_sym_other
245#define	conv_sym_value		conv32_sym_value
246#define	conv_sym_SPARC_value	conv32_sym_SPARC_value
247#endif
248
249extern	const char	*conv_bnd_obj(uint_t);
250extern	const char	*conv_bnd_type(uint_t);
251extern	const char	*conv_cap_tag(Xword);
252extern	const char	*conv_cap_val(Xword, Xword, Half);
253extern	const char	*conv_cap_val_hw1(Xword, Half);
254extern	const char	*conv_cap_val_sf1(Xword, Half);
255extern	const char	*conv_dyn_flag1(Xword);
256extern	const char	*conv_dyn_flag(Xword, int);
257extern	const char	*conv_dyn_posflag1(Xword, int);
258extern	const char	*conv_dyn_tag(Xword, Half, int);
259extern	const char	*conv_dyn_feature1(Xword, int);
260extern	const char	*conv_ehdr_class(uchar_t, int);
261extern	const char	*conv_ehdr_data(uchar_t, int);
262extern	const char	*conv_ehdr_flags(Half, Word);
263extern	const char	*conv_ehdr_mach(Half, int);
264extern	const char	*conv_ehdr_type(Half, int);
265extern	const char	*conv_ehdr_vers(Word, int);
266extern	int		conv_expn_field(CONV_EXPN_FIELD_ARG *);
267extern	const char	*conv_invalid_val(char *, size_t, Xword, int);
268extern	const char	*conv_phdr_flags(Word);
269extern	const char	*conv_phdr_type(Half, Word);
270extern	const char	*conv_reject_desc(Rej_desc *);
271extern	const char	*conv_reloc_type(Half, Word, int);
272extern	const char	*conv_reloc_386_type(Word, int);
273extern	const char	*conv_reloc_amd64_type(Word, int);
274extern	const char	*conv_reloc_SPARC_type(Word, int);
275extern	const char	*conv_sec_flags(Xword);
276extern	const char	*conv_sec_info(Word, Xword);
277extern	const char	*conv_sec_type(Half, Word, int);
278extern	const char	*conv_sym_info_bind(uchar_t, int);
279extern	const char	*conv_sym_info_type(Half, uchar_t, int);
280extern	const char	*conv_sym_shndx(Half);
281extern	const char	*conv_sym_other(uchar_t);
282extern	const char	*conv_sym_value(Half, uchar_t, Addr);
283extern	const char	*conv_sym_SPARC_value(Addr, int);
284
285#ifdef	__cplusplus
286}
287#endif
288
289#endif /* _CONV_H */
290