lint2.h revision 1.15
1/* $NetBSD: lint2.h,v 1.15 2021/08/22 12:15:37 rillig Exp $ */ 2 3/* 4 * Copyright (c) 1996 Christopher G. Demetriou. All Rights Reserved. 5 * Copyright (c) 1994, 1995 Jochen Pohl 6 * All Rights Reserved. 7 * 8 * Redistribution and use in source and binary forms, with or without 9 * modification, are permitted provided that the following conditions 10 * are met: 11 * 1. Redistributions of source code must retain the above copyright 12 * notice, this list of conditions and the following disclaimer. 13 * 2. Redistributions in binary form must reproduce the above copyright 14 * notice, this list of conditions and the following disclaimer in the 15 * documentation and/or other materials provided with the distribution. 16 * 3. All advertising materials mentioning features or use of this software 17 * must display the following acknowledgement: 18 * This product includes software developed by Jochen Pohl for 19 * The NetBSD Project. 20 * 4. The name of the author may not be used to endorse or promote products 21 * derived from this software without specific prior written permission. 22 * 23 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 24 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 25 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 26 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 27 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 28 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 29 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 30 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 31 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 32 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 33 */ 34 35#include "lint.h" 36 37/* 38 * Types are described by structures of type type_t. 39 */ 40struct lint2_type { 41 tspec_t t_tspec; /* type specifier */ 42 bool t_const : 1; /* constant */ 43 bool t_volatile : 1; /* volatile */ 44 bool t_vararg : 1; /* function has variable number of arguments */ 45 bool t_is_enum : 1; 46 bool t_proto : 1; /* this is a prototype */ 47 bool t_istag : 1; /* tag with _t_tag valid */ 48 bool t_istynam : 1; /* tag with _t_tynam valid */ 49 bool t_isuniqpos : 1; /* tag with _t_uniqpos valid */ 50 union { 51 int _t_dim; /* if the type is an ARRAY than this 52 is the dimension of the array. */ 53 struct hte *_t_tag; /* hash table entry of tag if 54 t_is_enum, STRUCT or UNION */ 55 struct hte *_t_tynam; /* hash table entry of typename if 56 t_is_enum, STRUCT or UNION */ 57 struct { 58 int p_line; 59 short p_file; 60 int p_uniq; 61 } _t_uniqpos; /* unique position, for untagged 62 untyped STRUCTs, UNIONS, and ENUMs, 63 if t_isuniqpos */ 64 struct lint2_type **_t_args; /* list of argument types if 65 this is a prototype */ 66 } t_u; 67 struct lint2_type *t_subt; /* element type (if ARRAY), 68 return type (if FUNC), 69 target type (if PTR) */ 70}; 71 72#define t_dim t_u._t_dim 73#define t_tag t_u._t_tag 74#define t_tynam t_u._t_tynam 75#define t_uniqpos t_u._t_uniqpos 76#define t_args t_u._t_args 77 78/* 79 * argument information 80 * 81 * Such a structure is created for each argument of a function call 82 * which is an integer constant or a constant string. 83 */ 84typedef struct arginf { 85 int a_num; /* # of argument (1..) */ 86 bool a_zero : 1; /* argument is 0 */ 87 bool a_pcon : 1; /* msb of argument is not set */ 88 bool a_ncon : 1; /* msb of argument is set */ 89 bool a_fmt : 1; /* a_fstrg points to format string */ 90 char *a_fstrg; /* format string */ 91 struct arginf *a_next; /* information for next const. argument */ 92} arginf_t; 93 94/* 95 * Keeps information about position in source file. 96 */ 97typedef struct { 98 u_short p_src; /* index of name of translation unit 99 (the name which was specified at the 100 command line) */ 101 u_short p_line; /* line number in p_src */ 102 u_short p_isrc; /* index of (included) file */ 103 u_short p_iline; /* line number in p_iline */ 104} pos_t; 105 106/* 107 * Used for definitions and declarations 108 * 109 * To save memory, variable sized structures are used. If 110 * all s_va, s_prfl and s_scfl are not set, the memory allocated 111 * for a symbol is only large enough to keep the first member of 112 * struct sym, s_s. 113 */ 114typedef struct sym { 115 struct { 116 pos_t s_pos; /* pos of def./decl. */ 117#ifndef lint 118 u_int s_def : 3; /* DECL, TDEF or DEF */ 119#else 120 def_t s_def; 121#endif 122 bool s_rval : 1; /* function has return value */ 123 bool s_inline : 1; /* function is inline */ 124 bool s_osdef : 1; /* old style function definition */ 125 bool s_static : 1; /* symbol is static */ 126 bool s_va : 1; /* check only first s_nva arguments */ 127 bool s_prfl : 1; /* printflike */ 128 bool s_scfl : 1; /* scanflike */ 129 u_short s_type; /* type */ 130 struct sym *s_next; /* next symbol with same name */ 131 } s_s; 132 short s_nva; 133 short s_nprfl; 134 short s_nscfl; 135} sym_t; 136 137#define s_pos s_s.s_pos 138#define s_rval s_s.s_rval 139#define s_osdef s_s.s_osdef 140#define s_inline s_s.s_inline 141#define s_static s_s.s_static 142#define s_def s_s.s_def 143#define s_va s_s.s_va 144#define s_prfl s_s.s_prfl 145#define s_scfl s_s.s_scfl 146#define s_type s_s.s_type 147#define s_next s_s.s_next 148 149/* 150 * Used to store information about function calls. 151 */ 152typedef struct fcall { 153 pos_t f_pos; /* position of call */ 154 bool f_rused : 1; /* return value used */ 155 bool f_rdisc : 1; /* return value discarded (casted to void) */ 156 u_short f_type; /* types of expected return value and args */ 157 arginf_t *f_args; /* information about constant arguments */ 158 struct fcall *f_next; /* next call of same function */ 159} fcall_t; 160 161/* 162 * Used to store information about usage of symbols other 163 * than for function calls. 164 */ 165typedef struct usym { 166 pos_t u_pos; /* position */ 167 struct usym *u_next; /* next usage */ 168} usym_t; 169 170/* 171 * hash table entry 172 */ 173typedef struct hte { 174 const char *h_name; /* name */ 175 bool h_used : 1; /* symbol is used */ 176 bool h_def : 1; /* symbol is defined */ 177 bool h_static : 1; /* static symbol */ 178 sym_t *h_syms; /* declarations and definitions */ 179 sym_t **h_lsym; /* points to s_next of last decl./def. */ 180 fcall_t *h_calls; /* function calls */ 181 fcall_t **h_lcall; /* points to f_next of last call */ 182 usym_t *h_usyms; /* usage info */ 183 usym_t **h_lusym; /* points to u_next of last usage info */ 184 struct hte *h_link; /* next hte with same hash function */ 185 struct hte *h_hte; /* pointer to other htes (for renames) */ 186} hte_t; 187 188#include "externs2.h" 189 190/* maps type indices into pointers to type structs */ 191static inline type_t * 192TP(u_short type_id) { 193 /* force sequence point for newly parsed type_id */ 194 return tlst[type_id]; 195} 196