• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

nickg / nvc / 14432819507

13 Apr 2025 07:41PM UTC coverage: 92.319% (+0.03%) from 92.294%
14432819507

push

github

nickg
Use a function to evaluate complex default values

60 of 62 new or added lines in 4 files covered. (96.77%)

245 existing lines in 5 files now uncovered.

68994 of 74734 relevant lines covered (92.32%)

420155.84 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

94.68
/src/common.c
1
//
2
//  Copyright (C) 2013-2024  Nick Gasson
3
//
4
//  This program is free software: you can redistribute it and/or modify
5
//  it under the terms of the GNU General Public License as published by
6
//  the Free Software Foundation, either version 3 of the License, or
7
//  (at your option) any later version.
8
//
9
//  This program is distributed in the hope that it will be useful,
10
//  but WITHOUT ANY WARRANTY; without even the implied warranty of
11
//  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12
//  GNU General Public License for more details.
13
//
14
//  You should have received a copy of the GNU General Public License
15
//  along with this program.  If not, see <http://www.gnu.org/licenses/>.
16
//
17

18
#include "util.h"
19
#include "common.h"
20
#include "diag.h"
21
#include "hash.h"
22
#include "ident.h"
23
#include "lib.h"
24
#include "lower.h"
25
#include "option.h"
26
#include "phase.h"
27
#include "scan.h"
28
#include "thread.h"
29
#include "type.h"
30
#include "vlog/vlog-phase.h"
31
#include "sdf/sdf-phase.h"
32
#include "sdf/sdf-util.h"
33

34
#include <assert.h>
35
#include <ctype.h>
36
#include <string.h>
37
#include <stdlib.h>
38
#include <inttypes.h>
39

40
static vhdl_standard_t  current_std  = STD_08;
41
static bool             have_set_std = false;
42
static ident_t          id_cache[NUM_WELL_KNOWN];
43
static text_buf_t      *syntax_buf = NULL;
44

45
int64_t assume_int(tree_t t)
369,544✔
46
{
47
   int64_t value;
369,544✔
48
   if (folded_int(t, &value))
369,544✔
49
      return value;
369,544✔
50

51
   fatal_at(tree_loc(t), "expression cannot be folded to "
×
52
            "an integer constant");
53
}
54

55
void range_bounds(tree_t r, int64_t *low, int64_t *high)
26,321✔
56
{
57
   assert(tree_kind(r) == T_RANGE);
26,321✔
58

59
   const int64_t left = assume_int(tree_left(r));
26,321✔
60
   const int64_t right = assume_int(tree_right(r));
26,321✔
61

62
   *low  = tree_subkind(r) == RANGE_TO ? left : right;
26,321✔
63
   *high = tree_subkind(r) == RANGE_TO ? right : left;
26,321✔
64
}
26,321✔
65

66
bool folded_int(tree_t t, int64_t *l)
3,844,886✔
67
{
68
   switch (tree_kind(t)) {
3,878,018✔
69
   case T_LITERAL:
2,800,019✔
70
      switch (tree_subkind(t)) {
2,800,019✔
71
      case L_PHYSICAL:
16,801✔
72
         if (tree_has_ref(t))
16,801✔
73
            return false;
74
         // Fall-through
75
      case L_INT:
76
         *l = tree_ival(t);
2,728,152✔
77
         return true;
2,728,152✔
78
      default:
79
         return false;
80
      }
81
   case T_QUALIFIED:
342✔
82
      return folded_int(tree_value(t), l);
342✔
83
   case T_REF:
849,194✔
84
      if (tree_has_ref(t)) {
849,194✔
85
         tree_t decl = tree_ref(t);
849,193✔
86
         switch (tree_kind(decl)) {
849,193✔
87
         case T_CONST_DECL:
40,422✔
88
            if (tree_has_value(decl))
40,422✔
89
               return folded_int(tree_value(decl), l);
32,445✔
90
            else
91
               return false;
92
         case T_ENUM_LIT:
740,621✔
93
            *l = tree_pos(decl);
740,621✔
94
            return true;
740,621✔
95
         case T_ALIAS:
345✔
96
            return folded_int(tree_value(decl), l);
345✔
97
         default:
98
            return false;
99
         }
100
      }
101
      // Fall-through
102
   default:
103
      return false;
104
   }
105
}
106

107
bool folded_real(tree_t t, double *l)
246,362✔
108
{
109
   switch (tree_kind(t)) {
246,371✔
110
   case T_LITERAL:
237,459✔
111
      if (tree_subkind(t) == L_REAL) {
237,459✔
112
         *l = tree_dval(t);
237,388✔
113
         return true;
237,388✔
114
      }
115
      else
116
         return false;
117
   case T_QUALIFIED:
9✔
118
      return folded_real(tree_value(t), l);
9✔
119
   default:
120
      return false;
121
   }
122
}
123

124
bool folded_length(tree_t r, int64_t *l)
65,835✔
125
{
126
   int64_t low, high;
65,835✔
127
   if (folded_bounds(r, &low, &high)) {
65,835✔
128
      *l = MAX(high - low + 1, 0);
62,157✔
129
      return true;
62,157✔
130
   }
131
   else
132
      return false;
133
}
134

135
bool folded_bounds(tree_t r, int64_t *low, int64_t *high)
1,604,380✔
136
{
137
   assert(tree_kind(r) == T_RANGE);
1,604,380✔
138

139
   const range_kind_t rkind = tree_subkind(r);
1,604,380✔
140

141
   if (rkind != RANGE_TO && rkind != RANGE_DOWNTO)
1,604,380✔
142
      return false;
143

144
   int64_t left, right;
1,591,580✔
145
   if (!folded_int(tree_left(r), &left))
1,591,580✔
146
      return false;
147
   else if (!folded_int(tree_right(r), &right))
1,466,571✔
148
      return false;
149

150
   switch (rkind) {
1,430,780✔
151
   case RANGE_TO:
1,305,038✔
152
      *low  = left;
1,305,038✔
153
      *high = right;
1,305,038✔
154
      return true;
1,305,038✔
155
   case RANGE_DOWNTO:
125,742✔
156
      *low  = right;
125,742✔
157
      *high = left;
125,742✔
158
      return true;
125,742✔
159
   default:
160
      return false;
161
   }
162
}
163

164
bool folded_bounds_real(tree_t r, double *low, double *high)
90,847✔
165
{
166
   assert(tree_kind(r) == T_RANGE);
90,847✔
167

168
   const range_kind_t rkind = tree_subkind(r);
90,847✔
169

170
   if (rkind != RANGE_TO && rkind != RANGE_DOWNTO)
90,847✔
171
      return false;
172

173
   double left, right;
90,844✔
174
   if (folded_real(tree_left(r), &left) && folded_real(tree_right(r), &right)) {
90,844✔
175
      switch (rkind) {
90,749✔
176
      case RANGE_TO:
90,749✔
177
         *low  = left;
90,749✔
178
         *high = right;
90,749✔
179
         return true;
90,749✔
180
      case RANGE_DOWNTO:
×
181
         *low  = right;
×
182
         *high = left;
×
183
         return true;
×
184
      default:
185
         return false;
186
      }
187
   }
188
   else
189
      return false;
95✔
190
}
191

192
bool folded_bool(tree_t t, bool *b)
40,865✔
193
{
194
   if (tree_kind(t) == T_REF) {
40,865✔
195
      tree_t decl = tree_ref(t);
10,770✔
196
      if (tree_kind(decl) == T_ENUM_LIT
10,770✔
197
          && type_ident(tree_type(decl)) == well_known(W_STD_BOOL)) {
8,406✔
198
         *b = (tree_pos(decl) == 1);
8,406✔
199
         return true;
8,406✔
200
      }
201
   }
202

203
   return false;
204
}
205

206
tree_t get_enum_lit(tree_t t, type_t type, int pos)
7,538✔
207
{
208
   type_t enum_type = type_base_recur(type ?: tree_type(t));
7,538✔
209
   tree_t lit = type_enum_literal(enum_type, pos);
7,538✔
210

211
   tree_t b = tree_new(T_REF);
7,538✔
212
   tree_set_loc(b, tree_loc(t));
7,538✔
213
   tree_set_ref(b, lit);
7,538✔
214
   tree_set_type(b, enum_type);
7,538✔
215
   tree_set_ident(b, tree_ident(lit));
7,538✔
216

217
   return b;
7,538✔
218
}
219

220
tree_t get_int_lit(tree_t t, type_t type, int64_t i)
42,703✔
221
{
222
   tree_t f = tree_new(T_LITERAL);
42,703✔
223
   tree_set_subkind(f, L_INT);
42,703✔
224
   tree_set_ival(f, i);
42,703✔
225
   tree_set_loc(f, tree_loc(t));
42,703✔
226
   tree_set_type(f, type ?: tree_type(t));
42,703✔
227

228
   return f;
42,703✔
229
}
230

231
tree_t get_discrete_lit(tree_t t, type_t type, int64_t i)
4,282✔
232
{
233
   if (type_is_enum(type)) {
4,282✔
234
      type_t base = type_base_recur(type);
68✔
235
      const int maxlit = type_enum_literals(base);
68✔
236
      if (i >= maxlit)
68✔
237
         return NULL;
238
      else
239
         return get_enum_lit(t, type, i);
68✔
240
   }
241
   else
242
      return get_int_lit(t, type, i);
4,214✔
243
}
244

245
tree_t get_real_lit(tree_t t, type_t type, double r)
×
246
{
247
   tree_t f = tree_new(T_LITERAL);
×
248
   tree_set_loc(f, tree_loc(t));
×
249
   tree_set_subkind(f, L_REAL);
×
250
   tree_set_dval(f, r);
×
251
   tree_set_type(f, type ?: tree_type(t));
×
252

253
   return f;
×
254
}
255

256
bool parse_value(type_t type, const char *str, parsed_value_t *value)
92✔
257
{
258
   type_t base = type_base_recur(type);
92✔
259
   const type_kind_t basek = type_kind(base);
92✔
260

261
   if (basek == T_ARRAY && type_is_character_array(base)) {
92✔
262
      value->enums = NULL;
17✔
263

264
      int map[256];
17✔
265
      for (int i = 0; i < ARRAY_LEN(map); i++)
4,369✔
266
         map[i] = INT_MAX;
4,352✔
267

268
      type_t elem = type_elem(base);
17✔
269

270
      const int nlits = type_enum_literals(elem);
17✔
271
      for (int i = 0; i < nlits; i++) {
2,591✔
272
         ident_t id = tree_ident(type_enum_literal(elem, i));
2,574✔
273
         if (ident_char(id, 0) == '\'')
2,574✔
274
            map[(uint8_t)ident_char(id, 1)] = i;
1,924✔
275
      }
276

277
      while (map[(uint8_t)*str] == INT_MAX && isspace_iso88591(*str))
20✔
278
         ++str;
3✔
279

280
      const bool quoted = map['\"'] == INT_MAX && *str == '\"';
17✔
281
      if (quoted) str++;
17✔
282

283
      const size_t max = strlen(str);
17✔
284
      enum_array_t *array = xmalloc_flex(sizeof(enum_array_t), max, 1);
17✔
285

286
      int n = 0, m;
17✔
287
      for (; *str != '\0' && (m = map[(uint8_t)*str]) != INT_MAX; str++, n++)
99✔
288
         array->values[n] = m;
65✔
289

290
      assert(n <= max);
17✔
291
      array->count = n;
17✔
292

293
      if (quoted && *str++ != '\"') {
17✔
294
         free(array);
1✔
295
         return false;
1✔
296
      }
297

298
      for (; *str; str++) {
20✔
299
         if (!isspace_iso88591(*str)) {
5✔
300
            free(array);
1✔
301
            return false;
1✔
302
         }
303
      }
304

305
      value->enums = array;
15✔
306
      return true;
15✔
307
   }
308

309
   while (isspace_iso88591(*str))
85✔
310
      ++str;
10✔
311

312
   switch (basek) {
75✔
313
   case T_INTEGER:
50✔
314
      {
315
         const bool is_negative = *str == '-';
50✔
316
         int num_digits = 0;
50✔
317

318
         if (is_negative) ++str;
50✔
319

320
         int64_t sum = 0;
321
         for (; isdigit_iso88591(*str) || (*str == '_'); str++) {
144✔
322
            if (*str != '_') {
94✔
323
               sum *= 10;
92✔
324
               sum += (*str - '0');
92✔
325
               num_digits++;
92✔
326
            }
327
         }
328

329
         value->integer = is_negative ? -sum : sum;
50✔
330

331
         if (num_digits == 0)
50✔
332
            return false;
333
      }
334
      break;
335

336
   case T_ENUM:
14✔
337
      {
338
         bool upcase = true;
14✔
339
         char *copy LOCAL = xstrdup(str), *p;
27✔
340
         for (p = copy; (*p != '\0') && !isspace_iso88591(*p); p++, str++) {
55✔
341
            if (*p == '\'')
41✔
342
               upcase = false;
343
            if (upcase)
23✔
344
               *p = toupper_iso88591(*p);
14✔
345
         }
346
         *p = '\0';
14✔
347

348
         ident_t id = ident_new(copy);
14✔
349

350
         value->integer = -1;
14✔
351

352
         const int nlits = type_enum_literals(base);
14✔
353
         for (int i = 0; i < nlits; i++) {
38✔
354
            if (tree_ident(type_enum_literal(base, i)) == id) {
37✔
355
               value->integer = i;
13✔
356
               break;
13✔
357
            }
358
         }
359

360
         if (value->integer == -1)
14✔
361
            return false;
1✔
362
      }
363
      break;
364

365
   case T_REAL:
6✔
366
      {
367
         char *eptr = NULL;
6✔
368
         value->real = strtod(str, &eptr);
6✔
369
         str = eptr;
6✔
370
      }
371
      break;
6✔
372

373
   case T_PHYSICAL:
5✔
374
      {
375
         char *eptr = NULL;
5✔
376
         double scale = strtod(str, &eptr);
5✔
377
         str = eptr;
5✔
378

379
         while (isspace_iso88591(*str)) ++str;
10✔
380

381
         char *copy LOCAL = xstrdup(str), *p;
10✔
382
         for (p = copy; *p && !isspace_iso88591(*p); p++, str++)
13✔
383
            *p = toupper_iso88591(*p);
8✔
384
         *p = '\0';
5✔
385

386
         if (p == copy)
5✔
387
            return false;
388

389
         ident_t id = ident_new(copy);
4✔
390

391
         value->integer = -1;
4✔
392

393
         const int nunits = type_units(base);
4✔
394
         for (int i = 0; i < nunits; i++) {
11✔
395
            tree_t u = type_unit(base, i);
11✔
396
            if (tree_ident(u) == id) {
11✔
397
               value->integer = scale * assume_int(tree_value(u));
4✔
398
               break;
4✔
399
            }
400
         }
401

402
         if (value->integer == -1)
4✔
403
            return false;
404
      }
405
      break;
406

407
   default:
408
      return false;
409
   }
410

411
   for (; *str; str++) {
84✔
412
      if (!isspace_iso88591(*str))
11✔
413
         return false;
414
   }
415

416
   return true;
417
}
418

419
tree_t make_ref(tree_t to)
7,771✔
420
{
421
   tree_t t = tree_new(T_REF);
7,771✔
422
   tree_set_ident(t, tree_ident(to));
7,771✔
423
   tree_set_ref(t, to);
7,771✔
424
   tree_set_type(t, tree_type(to));
7,771✔
425
   return t;
7,771✔
426
}
427

428
vhdl_standard_t standard(void)
2,539,564✔
429
{
430
   return current_std;
2,539,564✔
431
}
432

433
void set_standard(vhdl_standard_t s)
5,020✔
434
{
435
   current_std = s;
5,020✔
436
   have_set_std = true;
5,020✔
437
}
5,020✔
438

439
void set_default_standard(vhdl_standard_t s)
459✔
440
{
441
   if (!have_set_std)
459✔
442
      set_standard(s);
94✔
443
}
459✔
444

445
const char *standard_text(vhdl_standard_t s)
4,543✔
446
{
447
   static const char *text[] = {
4,543✔
448
      "1987", "1993", "2000", "2002", "2008", "2019"
449
   };
450

451
   if ((unsigned)s < ARRAY_LEN(text))
4,543✔
452
      return text[s];
4,543✔
453
   else
454
      return "????";
455
}
456

457
tree_t find_element_mode_indication(tree_t view, tree_t field, bool *converse)
397✔
458
{
459
   switch (tree_kind(view)) {
1,255✔
460
   case T_REF:
541✔
461
      return find_element_mode_indication(tree_ref(view), field, converse);
541✔
462

463
   case T_ALIAS:
144✔
464
      return find_element_mode_indication(tree_value(view), field, converse);
144✔
465

466
   case T_ATTR_REF:
173✔
467
      assert(tree_subkind(view) == ATTR_CONVERSE);
173✔
468
      *converse = !*converse;
173✔
469
      return find_element_mode_indication(tree_name(view), field, converse);
173✔
470

471
   case T_VIEW_DECL:
397✔
472
      {
473
         type_t view_type = tree_type(view);
397✔
474
         assert(type_kind(view_type) == T_VIEW);
397✔
475

476
         const int nelems = type_fields(view_type);
397✔
477
         for (int i = 0; i < nelems; i++) {
673✔
478
            tree_t e = type_field(view_type, i);
673✔
479
            if (tree_ref(e) == field)
673✔
480
               return e;
397✔
481
         }
482

483
         return NULL;
484
      }
485

486
   default:
×
487
      fatal_trace("unhandled tree kind %s in find_element_mode_indication",
488
                  tree_kind_str(tree_kind(view)));
489
   }
490
}
491

492
port_mode_t converse_mode(tree_t port, bool converse)
265✔
493
{
494
   const port_mode_t mode = tree_subkind(port);
265✔
495
   switch (mode) {
265✔
496
   case PORT_IN: return converse ? PORT_OUT : PORT_IN;
135✔
497
   case PORT_OUT: return converse ? PORT_IN : PORT_OUT;
121✔
498
   default: return mode;
499
   }
500
}
501

502
class_t class_of(tree_t t)
1,018,535✔
503
{
504
   switch (tree_kind(t)) {
1,072,073✔
505
   case T_VAR_DECL:
506
      return C_VARIABLE;
507
   case T_SIGNAL_DECL:
45,965✔
508
   case T_IMPLICIT_SIGNAL:
509
      return C_SIGNAL;
45,965✔
510
   case T_CONST_DECL:
37,011✔
511
      return C_CONSTANT;
37,011✔
512
   case T_PORT_DECL:
152,516✔
513
   case T_GENERIC_DECL:
514
   case T_PARAM_DECL:
515
   case T_EXTERNAL_NAME:
516
      return tree_class(t);
152,516✔
517
   case T_ENUM_LIT:
588,186✔
518
   case T_LITERAL:
519
   case T_STRING:
520
      return C_LITERAL;
588,186✔
521
   case T_FIELD_DECL:
1,056✔
522
   case T_ATTR_DECL:
523
      return C_DEFAULT;
1,056✔
524
   case T_VIEW_DECL:
126✔
525
      return C_VIEW;
126✔
526
   case T_UNIT_DECL:
7,580✔
527
      return C_UNITS;
7,580✔
528
   case T_ARCH:
47✔
529
      return C_ARCHITECTURE;
47✔
530
   case T_FUNC_DECL:
5,572✔
531
   case T_FUNC_BODY:
532
   case T_FUNC_INST:
533
   case T_FCALL:
534
   case T_PROT_FCALL:
535
      return C_FUNCTION;
5,572✔
536
   case T_PROC_DECL:
10,272✔
537
   case T_PROC_BODY:
538
   case T_PROC_INST:
539
   case T_PCALL:
540
   case T_PROT_PCALL:
541
      return C_PROCEDURE;
10,272✔
542
   case T_ENTITY:
135✔
543
      return C_ENTITY;
135✔
544
   case T_SUBTYPE_DECL:
18,782✔
545
      return C_SUBTYPE;
18,782✔
546
   case T_TYPE_DECL:
72,319✔
547
   case T_PROT_DECL:
548
   case T_PROT_BODY:
549
      return C_TYPE;
72,319✔
550
   case T_FILE_DECL:
1,113✔
551
      return C_FILE;
1,113✔
552
   case T_PROCESS:
138✔
553
   case T_BLOCK:
554
   case T_FOR:
555
   case T_INSTANCE:
556
   case T_CONCURRENT:
557
   case T_ELAB:
558
   case T_PSL_DECL:
559
   case T_PSL_DIRECT:
560
   case T_FOR_GENERATE:
561
   case T_IF_GENERATE:
562
   case T_CASE_GENERATE:
563
      return C_LABEL;
138✔
564
   case T_COMPONENT:
1✔
565
      return C_COMPONENT;
1✔
566
   case T_REF:
44,761✔
567
   case T_PROT_REF:
568
      return tree_has_ref(t) ? class_of(tree_ref(t)) : C_DEFAULT;
44,761✔
569
   case T_ARRAY_REF:
8,781✔
570
   case T_ARRAY_SLICE:
571
   case T_RECORD_REF:
572
   case T_ALL:
573
   case T_ALIAS:
574
   case T_QUALIFIED:
575
      return class_of(tree_value(t));
8,781✔
576
   case T_PACKAGE:
1,227✔
577
   case T_PACK_BODY:
578
   case T_PACK_INST:
579
      return C_PACKAGE;
1,227✔
580
   case T_CONFIGURATION:
1✔
581
      return C_CONFIGURATION;
1✔
582
   case T_LIBRARY:
1✔
583
      return C_LIBRARY;
1✔
584
   case T_ATTR_REF:
82✔
585
      switch (tree_subkind(t)) {
82✔
586
      case ATTR_DELAYED:
587
      case ATTR_STABLE:
588
      case ATTR_QUIET:
589
      case ATTR_TRANSACTION:
590
         return C_SIGNAL;
591
      default:
76✔
592
         return C_DEFAULT;
76✔
593
      }
594
   case T_CONTEXT:
×
595
      return C_CONTEXT;
×
596
   default:
×
597
      fatal_trace("missing class_of for %s", tree_kind_str(tree_kind(t)));
598
   }
599
}
600

601
bool class_has_type(class_t c)
862,354✔
602
{
603
   switch (c) {
862,354✔
604
   case C_LABEL:
605
   case C_ENTITY:
606
   case C_ARCHITECTURE:
607
   case C_COMPONENT:
608
   case C_CONFIGURATION:
609
   case C_PACKAGE:
610
   case C_LIBRARY:
611
      return false;
612
   default:
861,076✔
613
      return true;
861,076✔
614
   }
615
}
616

617
const char *class_str(class_t c)
447✔
618
{
619
   static const char *strs[] = {
447✔
620
      "default", "signal", "variable", "constant", "file", "entity",
621
      "component", "configuration", "architecture", "function", "package",
622
      "type", "subtype", "label", "procedure", "literal", "units", "library",
623
      "context", "view",
624
   };
625
   assert(c < ARRAY_LEN(strs));
447✔
626
   return strs[c];
447✔
627
}
628

629
const char *assoc_kind_str(assoc_kind_t akind)
9✔
630
{
631
   switch (akind) {
9✔
632
   case A_NAMED:  return "named";
633
   case A_CONCAT:
2✔
634
   case A_POS:    return "positional";
2✔
635
   case A_OTHERS: return "others";
3✔
636
   case A_SLICE:
1✔
637
   case A_RANGE:  return "range";
1✔
638
   default:       return "??";
×
639
   }
640
}
641

642
bool is_subprogram(tree_t t)
787,151✔
643
{
644
   switch (tree_kind(t)) {
787,151✔
645
   case T_FUNC_DECL:
646
   case T_FUNC_BODY:
647
   case T_FUNC_INST:
648
   case T_PROC_DECL:
649
   case T_PROC_BODY:
650
   case T_PROC_INST:
651
      return true;
652
   case T_GENERIC_DECL:
2,867✔
653
      {
654
         const class_t class = tree_class(t);
2,867✔
655
         return class == C_FUNCTION || class == C_PROCEDURE;
2,867✔
656
      }
657
   default:
617,242✔
658
      return false;
617,242✔
659
   }
660
}
661

662
bool is_loop_stmt(tree_t t)
421✔
663
{
664
   const tree_kind_t kind = tree_kind(t);
421✔
665
   return kind == T_WHILE || kind == T_FOR || kind == T_LOOP;
421✔
666
}
667

668
bool is_container(tree_t t)
10,475✔
669
{
670
   switch (tree_kind(t)) {
10,475✔
671
   case T_FUNC_BODY:
672
   case T_PROC_BODY:
673
   case T_ENTITY:
674
   case T_ARCH:
675
   case T_PACKAGE:
676
   case T_PACK_BODY:
677
   case T_CONFIGURATION:
678
   case T_BLOCK:
679
   case T_PROT_BODY:
680
   case T_ELAB:
681
   case T_FOR:
682
   case T_PROCESS:
683
   case T_PACK_INST:
684
      return true;
685
   default:
8,137✔
686
      return false;
8,137✔
687
   }
688
}
689

690
bool is_concurrent_block(tree_t t)
1,132✔
691
{
692
   switch (tree_kind(t)) {
1,132✔
693
   case T_ARCH:
694
   case T_ENTITY:
695
   case T_BLOCK:
696
   case T_IF_GENERATE:
697
   case T_FOR_GENERATE:
698
      return true;
699
   default:
376✔
700
      return false;
376✔
701
   }
702
}
703

704
bool is_package(tree_t t)
31,826✔
705
{
706
   switch (tree_kind(t)) {
31,826✔
707
   case T_PACKAGE:
708
   case T_PACK_BODY:
709
   case T_PACK_INST:
710
      return true;
711
   default:
1,085✔
712
      return false;
1,085✔
713
   }
714
}
715

716
bool is_design_unit(tree_t t)
38,673✔
717
{
718
   switch (tree_kind(t)) {
38,673✔
719
   case T_ENTITY:
720
   case T_ARCH:
721
   case T_PACKAGE:
722
   case T_PACK_BODY:
723
   case T_CONFIGURATION:
724
   case T_CONTEXT:
725
   case T_PACK_INST:
726
      return true;
727
   default:
8,628✔
728
      return false;
8,628✔
729
   }
730
}
731

732
bool is_literal(tree_t t)
40,151✔
733
{
734
   switch (tree_kind(t)) {
40,151✔
735
   case T_REF:
8,602✔
736
      return tree_has_ref(t) && tree_kind(tree_ref(t)) == T_ENUM_LIT;
10,609✔
737
   case T_LITERAL:
738
      return true;
739
   case T_STRING:
22,869✔
740
   default:
741
      return false;
22,869✔
742
   }
743
}
744

745
bool is_body(tree_t t)
12,092✔
746
{
747
   switch (tree_kind(t)) {
12,092✔
748
   case T_FUNC_BODY:
749
   case T_PROC_BODY:
750
   case T_PACK_BODY:
751
   case T_PROT_BODY:
752
      return true;
753
   default:
3,372✔
754
      return false;
3,372✔
755
   }
756
}
757

758
bool is_guarded_signal(tree_t decl)
13,875✔
759
{
760
   switch (tree_kind(decl)) {
13,875✔
761
   case T_PORT_DECL:
13,483✔
762
   case T_SIGNAL_DECL:
763
      return !!(tree_flags(decl) & (TREE_F_BUS | TREE_F_REGISTER));
13,483✔
764
   default:
765
      return false;
766
   }
767
}
768

769
bool is_type_decl(tree_t t)
1,007,633✔
770
{
771
   switch (tree_kind(t)) {
1,007,633✔
772
   case T_TYPE_DECL:
773
   case T_SUBTYPE_DECL:
774
   case T_PROT_DECL:
775
   case T_PROT_BODY:
776
      return true;
777
   default:
828,485✔
778
      return false;
828,485✔
779
   }
780
}
781

782
tree_t aliased_type_decl(tree_t decl)
125,934✔
783
{
784
   switch (tree_kind(decl)) {
126,198✔
785
   case T_ALIAS:
266✔
786
      {
787
         tree_t value = tree_value(decl);
266✔
788
         const tree_kind_t kind = tree_kind(value);
266✔
789
         if (kind == T_REF && tree_has_ref(value))
266✔
790
            return aliased_type_decl(tree_ref(value));
264✔
791
         else if (kind == T_ATTR_REF && is_type_attribute(tree_subkind(value)))
2✔
792
             return value;
793
         else
794
            return NULL;
×
795
      }
796
   case T_TYPE_DECL:
797
   case T_SUBTYPE_DECL:
798
   case T_PROT_DECL:
799
   case T_PROT_BODY:
800
      return decl;
801
   case T_GENERIC_DECL:
1,521✔
802
      if (tree_class(decl) == C_TYPE)
1,521✔
803
         return decl;
804
      else
805
         return NULL;
740✔
806
   default:
30,308✔
807
      return NULL;
30,308✔
808
   }
809
}
810

811
tree_t add_param(tree_t call, tree_t value, param_kind_t kind, tree_t name)
159,069✔
812
{
813
   tree_t p = tree_new(T_PARAM);
159,069✔
814
   tree_set_loc(p, tree_loc(value));
159,069✔
815
   tree_set_subkind(p, kind);
159,069✔
816
   tree_set_value(p, value);
159,069✔
817

818
   switch (kind) {
159,069✔
819
   case P_NAMED:
74✔
820
      assert(name != NULL);
74✔
821
      tree_set_name(p, name);
74✔
822
      break;
74✔
823
   case P_POS:
158,995✔
824
      tree_set_pos(p, tree_params(call));
158,995✔
825
      break;
158,995✔
826
   }
827

828
   tree_add_param(call, p);
159,069✔
829
   return p;
159,069✔
830
}
831

832
type_t array_aggregate_type(type_t array, int from_dim)
287✔
833
{
834
   if (type_is_none(array))
287✔
835
      return type_new(T_NONE);
2✔
836

837
   if (type_is_unconstrained(array)) {
285✔
838
      const int nindex = type_indexes(array);
45✔
839
      assert(from_dim < nindex);
45✔
840

841
      type_t type = type_new(T_ARRAY);
45✔
842
      type_set_ident(type, type_ident(array));
45✔
843
      type_set_elem(type, type_elem(array));
45✔
844

845
      for (int i = from_dim; i < nindex; i++)
90✔
846
         type_add_index(type, type_index(array, i));
45✔
847

848
      return type;
849
   }
850
   else {
851
      const int ndims = dimension_of(array);
240✔
852
      assert(from_dim < ndims);
240✔
853

854
      type_t base = type_new(T_ARRAY);
240✔
855
      type_set_ident(base, type_ident(array));
240✔
856
      type_set_elem(base, type_elem(array));
240✔
857

858
      tree_t constraint = tree_new(T_CONSTRAINT);
240✔
859
      tree_set_subkind(constraint, C_INDEX);
240✔
860

861
      type_t sub = type_new(T_SUBTYPE);
240✔
862
      type_set_base(sub, base);
240✔
863
      type_set_constraint(sub, constraint);
240✔
864

865
      for (int i = from_dim; i < ndims; i++) {
502✔
866
         tree_t r = range_of(array, i);
262✔
867
         if (r == NULL) {
262✔
868
            // Not enough constraints were provided for the type
869
            r = tree_new(T_RANGE);
1✔
870
            tree_set_subkind(r, RANGE_ERROR);
1✔
871
            tree_set_type(r, type_new(T_NONE));
1✔
872
         }
873

874
         type_add_index(base, tree_type(r));
262✔
875
         tree_add_range(constraint, r);
262✔
876
      }
877

878
      return sub;
879
   }
880
}
881

882
unsigned bits_for_range(int64_t low, int64_t high)
1,862,248✔
883
{
884
   if (low > high)
1,862,248✔
885
      return 0;   // Null range
886
   else if (low < 0) {
1,862,247✔
887
      // Signed integers
888
      if (low >= INT8_MIN && high <= INT8_MAX)
559,859✔
889
         return 8;
890
      else if (low >= INT16_MIN && high <= INT16_MAX)
554,454✔
891
         return 16;
892
      else if (low >= INT32_MIN && high <= INT32_MAX)
554,194✔
893
         return 32;
894
      else
895
         return 64;
125,378✔
896
   }
897
   else {
898
      // Unsigned integers
899
      if (high <= 1)
1,302,388✔
900
         return 1;
901
      else if (high <= UINT8_MAX)
658,961✔
902
         return 8;
903
      else if (high <= UINT16_MAX)
202,591✔
904
         return 16;
905
      else if (high <= UINT32_MAX)
199,234✔
906
         return 32;
907
      else
908
         return 64;
58,636✔
909
   }
910
}
911

912
unsigned dimension_of(type_t type)
1,206,342✔
913
{
914
   switch (type_kind(type)) {
2,239,540✔
915
   case T_SUBTYPE:
1,033,196✔
916
      return dimension_of(type_base(type));
1,033,196✔
917
   case T_GENERIC:
133✔
918
      switch (type_subkind(type)) {
133✔
919
      case GTYPE_ARRAY:
121✔
920
         return type_indexes(type);
121✔
921
      case GTYPE_ACCESS:
×
922
         return dimension_of(type_designated(type));
×
923
      case GTYPE_FILE:
924
      case GTYPE_PRIVATE:
925
         return 0;
926
      default:
12✔
927
         return 1;
12✔
928
      }
929
   case T_ARRAY:
1,199,185✔
930
      return type_indexes(type);
1,199,185✔
931
   case T_NONE:
932
   case T_RECORD:
933
   case T_INCOMPLETE:
934
   case T_FILE:
935
      return 0;
936
   case T_INTEGER:
6,965✔
937
   case T_REAL:
938
   case T_PHYSICAL:
939
   case T_ENUM:
940
      return type_dims(type);
6,965✔
941
   case T_ACCESS:
2✔
942
      return dimension_of(type_designated(type));
2✔
943
   default:
×
944
      fatal_trace("invalid type kind %s in dimension_of",
945
                  type_kind_str(type_kind(type)));
946
   }
947
}
948

949
tree_t range_of(type_t type, unsigned dim)
1,637,709✔
950
{
951
   switch (type_kind(type)) {
1,668,495✔
952
   case T_SUBTYPE:
1,233,149✔
953
      if (type_has_constraint(type)) {
1,233,149✔
954
         tree_t c = type_constraint(type);
1,202,363✔
955
         switch (tree_subkind(c)) {
1,202,363✔
956
         case C_INDEX:
1,202,363✔
957
         case C_RANGE:
958
            if (dim < tree_ranges(c))
1,202,363✔
959
               return tree_range(c, dim);
1,202,362✔
960
            else
961
               return NULL;   // Must be an error
962
         default:
×
963
            should_not_reach_here();
964
         }
965
      }
966
      else
967
         return range_of(type_base(type), dim);
30,786✔
968
   case T_INTEGER:
435,346✔
969
   case T_REAL:
970
   case T_PHYSICAL:
971
   case T_ENUM:
972
      return type_dim(type, dim);
435,346✔
973
   default:
×
974
      fatal_trace("invalid type kind %s for %s in range_of",
975
                  type_kind_str(type_kind(type)), type_pp(type));
976
   }
977
}
978

979
range_kind_t direction_of(type_t type, unsigned dim)
24,616✔
980
{
981
   switch (type_kind(type)) {
24,696✔
982
   case T_ENUM:
983
      return RANGE_TO;
984
   case T_NONE:
×
985
      return RANGE_ERROR;
×
986
   case T_INTEGER:
24,591✔
987
   case T_REAL:
988
   case T_PHYSICAL:
989
   case T_SUBTYPE:
990
      {
991
         tree_t r = range_of(type, dim);
24,591✔
992
         const range_kind_t rkind = tree_subkind(r);
24,591✔
993
         if (rkind == RANGE_EXPR) {
24,591✔
994
            // Return a fixed direction if possible
995
            tree_t value = tree_value(r);
149✔
996
            assert(tree_kind(value) == T_ATTR_REF);
149✔
997

998
            DEBUG_ONLY({
149✔
999
                  const attr_kind_t attr = tree_subkind(value);
1000
                  assert(attr == ATTR_RANGE || attr == ATTR_REVERSE_RANGE);
1001
               });
149✔
1002

1003
            tree_t name = tree_name(value);
149✔
1004
            if (tree_kind(name) == T_REF && tree_has_ref(name)) {
149✔
1005
               tree_t decl = tree_ref(name);
148✔
1006
               if (is_type_decl(decl))
148✔
1007
                  return direction_of(tree_type(decl), 0);
80✔
1008
            }
1009
         }
1010

1011
         return rkind;
1012
      }
1013
   default:
×
1014
      fatal_trace("invalid type kind %s in direction_of",
1015
                  type_kind_str(type_kind(type)));
1016
   }
1017
}
1018

1019
type_t index_type_of(type_t type, unsigned dim)
222,426✔
1020
{
1021
   if (dim >= dimension_of(type))
222,428✔
1022
      return NULL;
1023

1024
   type_t base = type_base_recur(type);
222,399✔
1025
   type_kind_t base_kind = type_kind(base);
222,399✔
1026
   if (base_kind == T_ARRAY)
222,399✔
1027
      return type_index(base, dim);
219,076✔
1028
   else if (base_kind == T_ENUM || base_kind == T_NONE)
3,323✔
1029
      return type;
1030
   else if (base_kind == T_GENERIC && type_subkind(base) == GTYPE_ARRAY)
3,169✔
1031
      return type_index(base, dim);
74✔
1032
   else if (base_kind == T_RECORD || base_kind == T_GENERIC)
3,095✔
1033
      return NULL;
1034
   else if (base_kind == T_ACCESS)
3,089✔
1035
      return index_type_of(type_designated(type), dim);
2✔
1036
   else
1037
      return tree_type(range_of(base, dim));
3,087✔
1038
}
1039

1040
int64_t rebase_index(type_t array_type, int dim, int64_t value)
384✔
1041
{
1042
   // Convert value which is in the range of array_type to a zero-based index
1043
   tree_t r = range_of(array_type, dim);
384✔
1044
   const int64_t left = assume_int(tree_left(r));
384✔
1045
   return (tree_subkind(r) == RANGE_TO) ? value - left : left - value;
384✔
1046
}
1047

1048
ident_t well_known(well_known_t id)
405,012✔
1049
{
1050
   assert(id < NUM_WELL_KNOWN);
405,012✔
1051
   return id_cache[id];
405,012✔
1052
}
1053

1054
well_known_t is_well_known(ident_t ident)
270,535✔
1055
{
1056
   well_known_t pos = 0;
270,535✔
1057
   for (; pos < NUM_WELL_KNOWN; pos++) {
14,696,636✔
1058
      if (id_cache[pos] == ident)
14,557,196✔
1059
         break;
1060
   }
1061

1062
   return pos;
270,535✔
1063
}
1064

1065
void intern_strings(void)
5,172✔
1066
{
1067
   id_cache[W_STD_STANDARD]    = ident_new("STD.STANDARD");
5,172✔
1068
   id_cache[W_ALL]             = ident_new("all");
5,172✔
1069
   id_cache[W_STD_BIT]         = ident_new("STD.STANDARD.BIT");
5,172✔
1070
   id_cache[W_STD_BOOL]        = ident_new("STD.STANDARD.BOOLEAN");
5,172✔
1071
   id_cache[W_STD_CHAR]        = ident_new("STD.STANDARD.CHARACTER");
5,172✔
1072
   id_cache[W_STD_NATURAL]     = ident_new("STD.STANDARD.NATURAL");
5,172✔
1073
   id_cache[W_STD_POSITIVE]    = ident_new("STD.STANDARD.POSITIVE");
5,172✔
1074
   id_cache[W_STD_INTEGER]     = ident_new("STD.STANDARD.INTEGER");
5,172✔
1075
   id_cache[W_STD_STRING]      = ident_new("STD.STANDARD.STRING");
5,172✔
1076
   id_cache[W_STD_REAL]        = ident_new("STD.STANDARD.REAL");
5,172✔
1077
   id_cache[W_STD_TIME]        = ident_new("STD.STANDARD.TIME");
5,172✔
1078
   id_cache[W_STD_BIT_VECTOR]  = ident_new("STD.STANDARD.BIT_VECTOR");
5,172✔
1079
   id_cache[W_IEEE_SIGNED]     = ident_new("IEEE.NUMERIC_STD.SIGNED");
5,172✔
1080
   id_cache[W_IEEE_UNSIGNED]   = ident_new("IEEE.NUMERIC_STD.UNSIGNED");
5,172✔
1081
   id_cache[W_IEEE_LOGIC]      = ident_new("IEEE.STD_LOGIC_1164.STD_LOGIC");
5,172✔
1082
   id_cache[W_IEEE_ULOGIC]     = ident_new("IEEE.STD_LOGIC_1164.STD_ULOGIC");
5,172✔
1083
   id_cache[W_IEEE_1164_AND]   = ident_new("IEEE.STD_LOGIC_1164.\"and\"");
5,172✔
1084
   id_cache[W_IEEE_1164_NAND]  = ident_new("IEEE.STD_LOGIC_1164.\"nand\"");
5,172✔
1085
   id_cache[W_IEEE_1164_OR]    = ident_new("IEEE.STD_LOGIC_1164.\"or\"");
5,172✔
1086
   id_cache[W_IEEE_1164_NOR]   = ident_new("IEEE.STD_LOGIC_1164.\"nor\"");
5,172✔
1087
   id_cache[W_IEEE_1164_XOR]   = ident_new("IEEE.STD_LOGIC_1164.\"xor\"");
5,172✔
1088
   id_cache[W_IEEE_1164_XNOR]  = ident_new("IEEE.STD_LOGIC_1164.\"xnor\"");
5,172✔
1089
   id_cache[W_FOREIGN]         = ident_new("FOREIGN");
5,172✔
1090
   id_cache[W_WORK]            = ident_new("WORK");
5,172✔
1091
   id_cache[W_STD]             = ident_new("STD");
5,172✔
1092
   id_cache[W_THUNK]           = ident_new("thunk");
5,172✔
1093
   id_cache[W_BODY]            = ident_new("body");
5,172✔
1094
   id_cache[W_CARET]           = ident_new("^");
5,172✔
1095
   id_cache[W_IEEE]            = ident_new("IEEE");
5,172✔
1096
   id_cache[W_IEEE_1164]       = ident_new("IEEE.STD_LOGIC_1164");
5,172✔
1097
   id_cache[W_ERROR]           = ident_new("$error");
5,172✔
1098
   id_cache[W_ELAB]            = ident_new("elab");
5,172✔
1099
   id_cache[W_NUMERIC_STD]     = ident_new("IEEE.NUMERIC_STD");
5,172✔
1100
   id_cache[W_NUMERIC_BIT]     = ident_new("IEEE.NUMERIC_BIT");
5,172✔
1101
   id_cache[W_NVC]             = ident_new("NVC");
5,172✔
1102
   id_cache[W_DEFAULT_CLOCK]   = ident_new("default clock");
5,172✔
1103
   id_cache[W_STD_REFLECTION]  = ident_new("STD.REFLECTION");
5,172✔
1104
   id_cache[W_NEVER_WAITS]     = ident_new("NEVER_WAITS");
5,172✔
1105
   id_cache[W_NVC_VERILOG]     = ident_new("NVC.VERILOG");
5,172✔
1106
   id_cache[W_NVC_PSL_SUPPORT] = ident_new("NVC.PSL_SUPPORT");
5,172✔
1107
   id_cache[W_SHAPE]           = ident_new("shape");
5,172✔
1108
   id_cache[W_INSTANCE_NAME]   = ident_new("instance_name");
5,172✔
1109
   id_cache[W_PATH_NAME]       = ident_new("path_name");
5,172✔
1110
   id_cache[W_VITAL]           = ident_new("VITAL");
5,172✔
1111
   id_cache[W_RESOLUTION]      = ident_new("resolution");
5,172✔
1112
   id_cache[W_TEXT_UTIL]       = ident_new("NVC.TEXT_UTIL");
5,172✔
1113

1114
   id_cache[W_IEEE_LOGIC_VECTOR] =
10,344✔
1115
      ident_new("IEEE.STD_LOGIC_1164.STD_LOGIC_VECTOR");
5,172✔
1116
   id_cache[W_IEEE_ULOGIC_VECTOR] =
10,344✔
1117
      ident_new("IEEE.STD_LOGIC_1164.STD_ULOGIC_VECTOR");
5,172✔
1118
   id_cache[W_IEEE_1164_RISING_EDGE] =
10,344✔
1119
      ident_new("IEEE.STD_LOGIC_1164.RISING_EDGE(sU)B");
5,172✔
1120
   id_cache[W_IEEE_1164_FALLING_EDGE] =
10,344✔
1121
      ident_new("IEEE.STD_LOGIC_1164.FALLING_EDGE(sU)B");
5,172✔
1122

1123
   id_cache[W_NUMERIC_STD_UNSIGNED] = ident_new("IEEE.NUMERIC_STD_UNSIGNED");
5,172✔
1124
   id_cache[W_NUMERIC_BIT_UNSIGNED] = ident_new("IEEE.NUMERIC_BIT_UNSIGNED");
5,172✔
1125

1126
   id_cache[W_OP_CCONV]               = ident_new("\"??\"");
5,172✔
1127
   id_cache[W_OP_AND]                 = ident_new("\"and\"");
5,172✔
1128
   id_cache[W_OP_OR]                  = ident_new("\"or\"");
5,172✔
1129
   id_cache[W_OP_NAND]                = ident_new("\"nand\"");
5,172✔
1130
   id_cache[W_OP_NOR]                 = ident_new("\"nor\"");
5,172✔
1131
   id_cache[W_OP_XOR]                 = ident_new("\"xor\"");
5,172✔
1132
   id_cache[W_OP_XNOR]                = ident_new("\"xnor\"");
5,172✔
1133
   id_cache[W_OP_EQUAL]               = ident_new("\"=\"");
5,172✔
1134
   id_cache[W_OP_NOT_EQUAL]           = ident_new("\"/=\"");
5,172✔
1135
   id_cache[W_OP_LESS_THAN]           = ident_new("\"<\"");
5,172✔
1136
   id_cache[W_OP_LESS_EQUAL]          = ident_new("\"<=\"");
5,172✔
1137
   id_cache[W_OP_GREATER_THAN]        = ident_new("\">\"");
5,172✔
1138
   id_cache[W_OP_GREATER_EQUAL]       = ident_new("\">=\"");
5,172✔
1139
   id_cache[W_OP_MATCH_EQUAL]         = ident_new("\"?=\"");
5,172✔
1140
   id_cache[W_OP_MATCH_NOT_EQUAL]     = ident_new("\"?/=\"");
5,172✔
1141
   id_cache[W_OP_MATCH_LESS_THAN]     = ident_new("\"?<\"");
5,172✔
1142
   id_cache[W_OP_MATCH_LESS_EQUAL]    = ident_new("\"?<=\"");
5,172✔
1143
   id_cache[W_OP_MATCH_GREATER_THAN]  = ident_new("\"?>\"");
5,172✔
1144
   id_cache[W_OP_MATCH_GREATER_EQUAL] = ident_new("\"?>=\"");
5,172✔
1145
   id_cache[W_OP_SLL]                 = ident_new("\"sll\"");
5,172✔
1146
   id_cache[W_OP_SRL]                 = ident_new("\"srl\"");
5,172✔
1147
   id_cache[W_OP_SLA]                 = ident_new("\"sla\"");
5,172✔
1148
   id_cache[W_OP_SRA]                 = ident_new("\"sra\"");
5,172✔
1149
   id_cache[W_OP_ROL]                 = ident_new("\"rol\"");
5,172✔
1150
   id_cache[W_OP_ROR]                 = ident_new("\"ror\"");
5,172✔
1151
   id_cache[W_OP_ADD]                 = ident_new("\"+\"");
5,172✔
1152
   id_cache[W_OP_MINUS]               = ident_new("\"-\"");
5,172✔
1153
   id_cache[W_OP_CONCAT]              = ident_new("\"&\"");
5,172✔
1154
   id_cache[W_OP_TIMES]               = ident_new("\"*\"");
5,172✔
1155
   id_cache[W_OP_DIVIDE]              = ident_new("\"/\"");
5,172✔
1156
   id_cache[W_OP_MOD]                 = ident_new("\"mod\"");
5,172✔
1157
   id_cache[W_OP_REM]                 = ident_new("\"rem\"");
5,172✔
1158
   id_cache[W_OP_EXPONENT]            = ident_new("\"**\"");
5,172✔
1159
   id_cache[W_OP_ABS]                 = ident_new("\"abs\"");
5,172✔
1160
   id_cache[W_OP_NOT]                 = ident_new("\"not\"");
5,172✔
1161
}
5,172✔
1162

1163
bool is_uninstantiated_package(tree_t pack)
20,252✔
1164
{
1165
   return tree_kind(pack) == T_PACKAGE
20,252✔
1166
      && tree_generics(pack) > 0
19,938✔
1167
      && tree_genmaps(pack) == 0;
22,068✔
1168
}
1169

1170
bool is_uninstantiated_subprogram(tree_t decl)
98,938✔
1171
{
1172
   switch (tree_kind(decl)) {
98,938✔
1173
   case T_FUNC_DECL:
98,406✔
1174
   case T_FUNC_BODY:
1175
   case T_PROC_DECL:
1176
   case T_PROC_BODY:
1177
      return tree_generics(decl) > 0;
98,406✔
1178
   default:
1179
      return false;
1180
   }
1181
}
1182

1183
bool is_anonymous_subtype(type_t type)
185,024✔
1184
{
1185
   return type_kind(type) == T_SUBTYPE && !type_has_ident(type);
185,024✔
1186
}
1187

1188
bool unit_needs_cgen(tree_t unit)
198✔
1189
{
1190
   switch (tree_kind(unit)) {
198✔
1191
   case T_PACK_INST:
1192
      return true;
UNCOV
1193
   case T_PACK_BODY:
×
1194
      {
UNCOV
1195
         tree_t pack = tree_primary(unit);
×
1196
         return package_needs_body(pack) && !is_uninstantiated_package(pack);
×
1197
      }
1198
   case T_PACKAGE:
12✔
1199
      return !package_needs_body(unit) && !is_uninstantiated_package(unit);
24✔
UNCOV
1200
   default:
×
1201
      return false;
×
1202
   }
1203
}
1204

1205
bool package_needs_body(tree_t pack)
1,932✔
1206
{
1207
   assert(tree_kind(pack) == T_PACKAGE);
1,932✔
1208

1209
   const int ndecls = tree_decls(pack);
1,932✔
1210
   for (int i = 0; i < ndecls; i++) {
91,416✔
1211
      tree_t d = tree_decl(pack, i);
90,916✔
1212
      const tree_kind_t dkind = tree_kind(d);
90,916✔
1213
      if ((dkind == T_FUNC_DECL || dkind == T_PROC_DECL)
90,916✔
1214
          && !(tree_flags(d) & TREE_F_PREDEFINED))
79,843✔
1215
         return true;
1216
      else if (dkind == T_CONST_DECL && !tree_has_value(d))
89,643✔
1217
         return true;
1218
      else if (dkind == T_PROT_DECL)
89,575✔
1219
         return true;
1220
   }
1221

1222
   return false;
1223
}
1224

1225
static tree_t cached_unit(tree_t hint, tree_t *cache, well_known_t lib_name,
13,894✔
1226
                          well_known_t unit_name)
1227
{
1228
   const vhdl_standard_t curr = standard();
13,894✔
1229

1230
   if (cache[curr] == NULL) {
13,894✔
1231
      if (hint != NULL)
4,348✔
1232
         cache[curr] = hint;
1,399✔
1233
      else {
1234
         lib_t std = lib_require(well_known(lib_name));
2,949✔
1235
         cache[curr] = lib_get(std, well_known(unit_name));
2,949✔
1236
         assert(cache[curr] != NULL);
2,949✔
1237
      }
1238
   }
1239

1240
   assert(hint == NULL || hint == cache[curr]);
13,894✔
1241
   return cache[curr];
13,894✔
1242
}
1243

1244
static tree_t cached_std(tree_t hint)
13,495✔
1245
{
1246
   static tree_t standard_cache[STD_19 + 1] = {};
13,495✔
1247
   return cached_unit(hint, standard_cache, W_STD, W_STD_STANDARD);
13,495✔
1248
}
1249

1250
static tree_t search_type_decls(tree_t container, ident_t name)
13,790✔
1251
{
1252
   const int ndecls = tree_decls(container);
13,790✔
1253

1254
   for (int i = 0; i < ndecls; i++) {
890,942✔
1255
      tree_t d = tree_decl(container, i);
890,942✔
1256
      if (is_type_decl(d) && tree_ident(d) == name)
890,942✔
1257
         return d;
13,790✔
1258
   }
1259

1260
   return NULL;
1261
}
1262

1263
type_t std_type(tree_t std, std_type_t which)
940,387✔
1264
{
1265
   static type_t cache[STD_FILE_OPEN_STATE + 1] = {};
940,387✔
1266
   assert(which < ARRAY_LEN(cache));
940,387✔
1267

1268
   if (cache[which] == NULL) {
940,387✔
1269
      const char *names[] = {
13,495✔
1270
         "universal_integer",
1271
         "universal_real",
1272
         "INTEGER",
1273
         "REAL",
1274
         "BOOLEAN",
1275
         "STRING",
1276
         "TIME",
1277
         "BIT",
1278
         "FILE_OPEN_KIND",
1279
         "FILE_OPEN_STATUS",
1280
         "NATURAL",
1281
         "BIT_VECTOR",
1282
         "SEVERITY_LEVEL",
1283
         "FILE_ORIGIN_KIND",
1284
         "FILE_OPEN_STATE",
1285
      };
1286

1287
      tree_t d = search_type_decls(cached_std(std), ident_new(names[which]));
13,495✔
1288
      if (d == NULL)
13,495✔
1289
         fatal_trace("cannot find standard type %s", names[which]);
1290

1291
      // Do not cache standard types while bootstrapping as the GC will
1292
      // move the objects after parsing
1293
      static int can_cache = -1;
13,495✔
1294
      if (can_cache == -1) can_cache = !opt_get_int(OPT_BOOTSTRAP);
13,495✔
1295

1296
      if (can_cache)
13,495✔
1297
         return (cache[which] = tree_type(d));
13,305✔
1298
      else
1299
         return tree_type(d);
190✔
1300
   }
1301
   else
1302
      return cache[which];
1303
}
1304

1305
type_t ieee_type(ieee_type_t which)
1,254✔
1306
{
1307
   static type_t cache[IEEE_STD_LOGIC + 1] = {};
1,254✔
1308
   assert(which < ARRAY_LEN(cache));
1,254✔
1309

1310
   if (cache[which] == NULL) {
1,254✔
1311
      const char *names[] = {
112✔
1312
         "STD_ULOGIC",
1313
         "STD_LOGIC",
1314
      };
1315

1316
      static tree_t ieee_cache[STD_19 + 1] = {};
112✔
1317
      tree_t unit = cached_unit(NULL, ieee_cache, W_IEEE, W_IEEE_1164);
112✔
1318

1319
      tree_t d = search_type_decls(unit, ident_new(names[which]));
112✔
1320
      if (d == NULL)
112✔
1321
         fatal_trace("cannot find IEEE type %s", names[which]);
1322

1323
      // STD.STANDARD cannot depend on IEEE
1324
      assert(!opt_get_int(OPT_BOOTSTRAP));
112✔
1325

1326
      return (cache[which] = tree_type(d));
112✔
1327
   }
1328
   else
1329
      return cache[which];
1330
}
1331

1332
static tree_t cached_verilog(void)
255✔
1333
{
1334
   static tree_t verilog_cache[STD_19 + 1] = {};
255✔
1335
   return cached_unit(NULL, verilog_cache, W_NVC, W_NVC_VERILOG);
255✔
1336
}
1337

1338
type_t verilog_type(verilog_type_t which)
417✔
1339
{
1340
   static type_t cache[VERILOG_WIRE_ARRAY + 1] = {};
417✔
1341
   assert(which < ARRAY_LEN(cache));
417✔
1342

1343
   if (cache[which] == NULL) {
417✔
1344
      const char *names[] = {
151✔
1345
         [VERILOG_LOGIC] = "T_LOGIC",
1346
         [VERILOG_LOGIC_ARRAY] = "T_LOGIC_ARRAY",
1347
         [VERILOG_INT64] = "T_INT64",
1348
         [VERILOG_NET_VALUE] = "T_NET_VALUE",
1349
         [VERILOG_NET_ARRAY] = "T_NET_ARRAY",
1350
         [VERILOG_WIRE] = "T_WIRE",
1351
         [VERILOG_WIRE_ARRAY] = "T_WIRE_ARRAY",
1352
      };
1353

1354
      tree_t d = search_type_decls(cached_verilog(), ident_new(names[which]));
151✔
1355
      if (d == NULL)
151✔
1356
         fatal_trace("cannot find NVC.VERILOG type %s", names[which]);
1357

1358
      // STD.STANDARD cannot depend on NVC.VERILOG
1359
      assert(!opt_get_int(OPT_BOOTSTRAP));
151✔
1360

1361
      return (cache[which] = tree_type(d));
151✔
1362
   }
1363
   else
1364
      return cache[which];
1365
}
1366

1367
type_t reflection_type(reflect_type_t which)
189✔
1368
{
1369
   static type_t cache[REFLECT_SUBTYPE_MIRROR + 1] = {};
189✔
1370
   assert(which < ARRAY_LEN(cache));
189✔
1371

1372
   if (cache[which] == NULL) {
189✔
1373
      const char *names[] = {
32✔
1374
         "VALUE_MIRROR",
1375
         "SUBTYPE_MIRROR",
1376
      };
1377

1378
      static tree_t reflect_cache[STD_19 + 1] = {};
32✔
1379
      tree_t unit = cached_unit(NULL, reflect_cache, W_STD, W_STD_REFLECTION);
32✔
1380

1381
      tree_t d = search_type_decls(unit, ident_new(names[which]));
32✔
1382
      if (d == NULL)
32✔
1383
         fatal_trace("cannot find REFLECTION type %s", names[which]);
1384

1385
      // STD.STANDARD cannot depend on REFLECTION
1386
      assert(!opt_get_int(OPT_BOOTSTRAP));
32✔
1387

1388
      return (cache[which] = tree_type(d));
32✔
1389
   }
1390
   else
1391
      return cache[which];
1392
}
1393

1394
bool is_open_coded_builtin(subprogram_kind_t kind)
287,978✔
1395
{
1396
   switch (kind) {
287,978✔
1397
   case S_ADD:
1398
   case S_SUB:
1399
   case S_DIV:
1400
   case S_MUL:
1401
   case S_MUL_PR:
1402
   case S_MUL_RP:
1403
   case S_MUL_PI:
1404
   case S_MUL_IP:
1405
   case S_DIV_PR:
1406
   case S_DIV_PP:
1407
   case S_DIV_PI:
1408
   case S_IDENTITY:
1409
   case S_NEGATE:
1410
   case S_SCALAR_LT:
1411
   case S_SCALAR_LE:
1412
   case S_SCALAR_GT:
1413
   case S_SCALAR_GE:
1414
   case S_SCALAR_EQ:
1415
   case S_SCALAR_NEQ:
1416
   case S_ABS:
1417
   case S_MOD:
1418
   case S_REM:
1419
   case S_EXP:
1420
   case S_MUL_RI:
1421
   case S_MUL_IR:
1422
   case S_DIV_RI:
1423
   case S_CONCAT:
1424
   case S_SCALAR_AND:
1425
   case S_SCALAR_OR:
1426
   case S_SCALAR_NOT:
1427
   case S_SCALAR_NAND:
1428
   case S_SCALAR_NOR:
1429
   case S_SCALAR_XOR:
1430
   case S_SCALAR_XNOR:
1431
   case S_FILE_OPEN1:
1432
   case S_FILE_OPEN2:
1433
   case S_FILE_READ:
1434
   case S_FILE_WRITE:
1435
   case S_DEALLOCATE:
1436
      return true;
1437
   default:
117,665✔
1438
      return false;
117,665✔
1439
   }
1440
}
1441

UNCOV
1442
tree_t std_func(ident_t mangled)
×
1443
{
UNCOV
1444
   tree_t std = cached_std(NULL);
×
1445

UNCOV
1446
   const int ndecls = tree_decls(std);
×
1447
   for (int i = 0; i < ndecls; i++) {
×
1448
      tree_t d = tree_decl(std, i);
×
1449
      if (is_subprogram(d) && tree_has_ident2(d) && tree_ident2(d) == mangled)
×
1450
         return d;
×
1451
   }
1452

1453
   return NULL;
1454
}
1455

1456
tree_t verilog_func(ident_t mangled)
104✔
1457
{
1458
   tree_t pack = cached_verilog();
104✔
1459

1460
   const int ndecls = tree_decls(pack);
104✔
1461
   for (int i = 0; i < ndecls; i++) {
9,730✔
1462
      tree_t d = tree_decl(pack, i);
9,730✔
1463
      if (is_subprogram(d) && tree_ident2(d) == mangled)
9,730✔
1464
         return d;
104✔
1465
   }
1466

1467
   fatal_trace("missing Verilog helper function %s", istr(mangled));
1468
}
1469

1470
tree_t name_to_ref(tree_t name)
96,632✔
1471
{
1472
   tree_kind_t kind;
96,632✔
1473
   while ((kind = tree_kind(name)) != T_REF) {
110,037✔
1474
      switch (kind) {
15,080✔
1475
      case T_ARRAY_REF:
13,405✔
1476
      case T_ARRAY_SLICE:
1477
      case T_RECORD_REF:
1478
      case T_ALL:
1479
         name = tree_value(name);
13,405✔
1480
         break;
13,405✔
1481
      default:
1482
         return NULL;
1483
      }
1484
   }
1485

1486
   return name;
1487
}
1488

1489
const char *port_mode_str(port_mode_t mode)
44✔
1490
{
1491
   const char *mode_str[] = {
44✔
1492
      "INVALID", "IN", "OUT", "INOUT", "BUFFER", "LINKAGE", "VIEW", "VIEW"
1493
   };
1494
   assert(mode < ARRAY_LEN(mode_str));
44✔
1495
   return mode_str[mode];
44✔
1496
}
1497

1498
void mangle_one_type(text_buf_t *buf, type_t type)
171,590✔
1499
{
1500
   ident_t ident = type_ident(type);
171,590✔
1501

1502
   char code = 0;
171,590✔
1503
   switch (is_well_known(ident)) {
171,590✔
1504
   case W_STD_INTEGER:        code = 'I'; break;
1505
   case W_STD_STRING:         code = 'S'; break;
3,448✔
1506
   case W_STD_REAL:           code = 'R'; break;
3,555✔
1507
   case W_STD_BOOL:           code = 'B'; break;
23,053✔
1508
   case W_STD_CHAR:           code = 'C'; break;
625✔
1509
   case W_STD_TIME:           code = 'T'; break;
916✔
1510
   case W_STD_NATURAL:        code = 'N'; break;
4,231✔
1511
   case W_STD_POSITIVE:       code = 'P'; break;
365✔
1512
   case W_STD_BIT:            code = 'J'; break;
2,637✔
1513
   case W_STD_BIT_VECTOR:     code = 'Q'; break;
2,698✔
1514
   case W_IEEE_LOGIC:         code = 'L'; break;
292✔
1515
   case W_IEEE_ULOGIC:        code = 'U'; break;
4,629✔
1516
   case W_IEEE_LOGIC_VECTOR:  code = 'V'; break;
1,658✔
1517
   case W_IEEE_ULOGIC_VECTOR: code = 'Y'; break;
1,393✔
1518
   default: break;
1519
   }
1520

1521
   if (code)
49,500✔
1522
      tb_append(buf, code);
62,149✔
1523
   else {
1524
      tb_printf(buf, "%zu", ident_len(ident));
109,441✔
1525
      tb_istr(buf, ident);
109,441✔
1526
   }
1527
}
171,590✔
1528

1529
ident_t get_call_context(ident_t mangled)
22,649✔
1530
{
1531
   const char *str = istr(mangled), *p = str, *end = NULL;
22,649✔
1532
   for (; *p; p++) {
613,815✔
1533
      if (*p == '(') break;
586,090✔
1534
      if (*p == '.') end = p;
568,517✔
1535
   }
1536
   assert(end != NULL);
22,649✔
1537

1538
   return ident_new_n(str, end - str);
22,649✔
1539
}
1540

1541
tree_t primary_unit_of(tree_t unit)
27,228✔
1542
{
1543
   switch (tree_kind(unit)) {
27,228✔
1544
   case T_ENTITY:
1545
   case T_COMPONENT:
1546
   case T_PACKAGE:
1547
   case T_BLOCK:
1548
   case T_ELAB:
1549
   case T_PACK_INST:
1550
      return unit;
1551
   case T_ARCH:
15,801✔
1552
   case T_CONFIGURATION:
1553
   case T_PACK_BODY:
1554
      return tree_primary(unit);
15,801✔
UNCOV
1555
   default:
×
1556
      fatal_trace("invalid kind %s in primary_unit_of",
1557
                  tree_kind_str(tree_kind(unit)));
1558
   }
1559
}
1560

1561
unsigned get_case_choice_char(tree_t value, int depth)
8,448✔
1562
{
1563
   switch (tree_kind(value)) {
9,235✔
1564
   case T_STRING:
8,130✔
1565
      if (depth < tree_chars(value))
8,130✔
1566
         return assume_int(tree_char(value, depth));
8,129✔
1567
      else
1568
         return ~0;   // Out of bounds
1569

1570
   case T_AGGREGATE:
318✔
1571
      {
1572
         const int nassocs = tree_assocs(value);
318✔
1573
         type_t type = tree_type(value);
318✔
1574

1575
         for (int i = 0, pos = 0; i < nassocs; i++) {
480✔
1576
            tree_t a = tree_assoc(value, i);
479✔
1577
            switch (tree_subkind(a)) {
479✔
UNCOV
1578
            case A_NAMED:
×
1579
               if (rebase_index(type, 0, assume_int(tree_name(a))) == depth)
×
1580
                  return assume_int(tree_value(a));
×
1581
               break;
1582

1583
            case A_POS:
23✔
1584
               if (pos++ == (unsigned)depth)
23✔
1585
                  return assume_int(tree_value(a));
13✔
1586
               break;
1587

1588
            case A_CONCAT:
384✔
1589
               {
1590
                  tree_t left = tree_value(a);
384✔
1591

1592
                  type_t left_type = tree_type(left);
384✔
1593
                  if (type_is_unconstrained(left_type))
384✔
UNCOV
1594
                     fatal_at(tree_loc(left), "sorry, this expression is not "
×
1595
                              "currently supported in a case choice");
1596

1597
                  tree_t lr = range_of(tree_type(left), 0);
384✔
1598
                  int64_t left_len;
384✔
1599
                  if (!folded_length(lr, &left_len))
384✔
UNCOV
1600
                     fatal_at(tree_loc(left), "cannot determine length of "
×
1601
                              "aggregate element");
1602

1603
                  if (depth < pos + left_len)
384✔
1604
                     return get_case_choice_char(left, depth - pos);
256✔
1605

1606
                  pos += left_len;
128✔
1607
               }
1608
               break;
128✔
1609

UNCOV
1610
            case A_OTHERS:
×
1611
               return assume_int(tree_value(a));
×
1612

1613
            case A_SLICE:
72✔
1614
               {
1615
                  tree_t base = tree_value(a);
72✔
1616
                  tree_t r = tree_range(a, 0);
72✔
1617

1618
                  const int64_t rleft = assume_int(tree_left(r));
72✔
1619
                  const int64_t rright = assume_int(tree_right(r));
72✔
1620

1621
                  const int64_t loffset = rebase_index(type, 0, rleft);
72✔
1622
                  const int64_t roffset = rebase_index(type, 0, rright);
72✔
1623

1624
                  if (depth >= loffset && depth <= roffset)
72✔
1625
                     return get_case_choice_char(base, depth - loffset);
48✔
1626
               }
1627
            }
1628
         }
1629

1630
         // This will produce an error during bounds checking
1631
         return ~0;
1632
      }
1633

1634
   case T_REF:
547✔
1635
      {
1636
         tree_t decl = tree_ref(value);
547✔
1637
         assert(tree_kind(decl) == T_CONST_DECL || tree_kind(decl) == T_ALIAS);
547✔
1638
         assert(tree_has_value(decl));
547✔
1639
         return get_case_choice_char(tree_value(decl), depth);
547✔
1640
      }
1641

1642
   case T_ARRAY_SLICE:
240✔
1643
      {
1644
         tree_t base = tree_value(value);
240✔
1645
         tree_t r = tree_range(value, 0);
240✔
1646
         const int64_t rleft = assume_int(tree_left(r));
240✔
1647
         const int64_t offset = rebase_index(tree_type(base), 0, rleft);
240✔
1648
         return get_case_choice_char(base, depth + offset);
240✔
1649
      }
1650

UNCOV
1651
   default:
×
1652
      fatal_at(tree_loc(value), "unsupported tree type %s in case choice",
×
1653
               tree_kind_str(tree_kind(value)));
1654
   }
1655
}
1656

1657
int64_t encode_case_choice(tree_t value, int length, int bits)
1,114✔
1658
{
1659
   uint64_t enc = 0;
1,114✔
1660
   for (int i = 0; i < length; i++) {
9,236✔
1661
      if (bits > 0) {
8,122✔
1662
         enc <<= bits;
1,685✔
1663
         enc |= get_case_choice_char(value, i);
1,685✔
1664
      }
1665
      else {
1666
         enc *= 0x27d4eb2d;
6,437✔
1667
         enc += get_case_choice_char(value, i);
6,437✔
1668
      }
1669
   }
1670

1671
   return enc;
1,114✔
1672
}
1673

1674
void to_string(text_buf_t *tb, type_t type, int64_t value)
572✔
1675
{
1676
   if (type_is_integer(type))
572✔
1677
      tb_printf(tb, "%"PRIi64, value);
438✔
1678
   else if (type_is_enum(type)) {
134✔
1679
      type_t base = type_base_recur(type);
62✔
1680
      if (value < 0 || value >= type_enum_literals(base))
62✔
1681
         tb_printf(tb, "%"PRIi64, value);
3✔
1682
      else
1683
         tb_cat(tb, istr(tree_ident(type_enum_literal(base, value))));
59✔
1684
   }
1685
   else if (type_is_physical(type)) {
72✔
1686
      type_t base = type_base_recur(type);
24✔
1687
      const unsigned nunits = type_units(base);
24✔
1688
      tree_t max_unit = NULL;
24✔
1689
      int64_t max_unit_value = 0;
24✔
1690

1691
      // Find the largest unit that evenly divides the given value
1692
      for (unsigned u = 0; u < nunits; u++) {
216✔
1693
         tree_t unit = type_unit(base, u);
192✔
1694
         const int64_t unit_value = assume_int(tree_value(unit));
192✔
1695
         if ((unit_value > max_unit_value) && (value % unit_value == 0)) {
192✔
1696
            max_unit = unit;
90✔
1697
            max_unit_value = unit_value;
90✔
1698
         }
1699
      }
1700
      assert(max_unit);
24✔
1701

1702
      tb_printf(tb, "%"PRIi64" %s", value / max_unit_value,
24✔
1703
                istr(tree_ident(max_unit)));
1704
   }
1705
   else if (type_is_real(type)) {
48✔
1706
      union { int64_t i; double r; } u = { .i = value };
42✔
1707
      tb_printf(tb, "%.17g", u.r);
42✔
1708
   }
1709
   else if (type_is_access(type)) {
6✔
1710
      if (value == 0)
6✔
1711
         tb_cat(tb, "NULL");
3✔
1712
      else
1713
         tb_printf(tb, "%p", (void *)value);
3✔
1714
   }
1715
}
572✔
1716

1717
static bool is_static(tree_t expr)
5,904✔
1718
{
1719
   switch (tree_kind(expr)) {
6,008✔
1720
   case T_REF:
688✔
1721
      {
1722
         tree_t decl = tree_ref(expr);
688✔
1723
         switch (tree_kind(decl)) {
688✔
1724
         case T_CONST_DECL:
179✔
1725
            return !!(tree_flags(decl) & TREE_F_GLOBALLY_STATIC);
179✔
1726
         case T_UNIT_DECL:
1727
         case T_ENUM_LIT:
1728
         case T_GENERIC_DECL:
1729
            return true;
UNCOV
1730
         case T_ALIAS:
×
1731
            return is_static(tree_value(decl));
×
1732
         default:
191✔
1733
            return false;
191✔
1734
         }
1735
      }
1736

1737
   case T_LITERAL:
1738
   case T_STRING:
1739
      return true;
1740

1741
   case T_FCALL:
402✔
1742
      return !!(tree_flags(expr) & (TREE_F_LOCALLY_STATIC
402✔
1743
                                    | TREE_F_GLOBALLY_STATIC));
1744

1745
   case T_RECORD_REF:
101✔
1746
      return is_static(tree_value(expr));
101✔
1747

1748
   case T_ARRAY_REF:
60✔
1749
      {
1750
         if (!is_static(tree_value(expr)))
60✔
1751
            return false;
1752

1753
         const int nparams = tree_params(expr);
60✔
1754
         for (int i = 0; i < nparams; i++) {
120✔
1755
            if (!is_static(tree_value(tree_param(expr, i))))
60✔
1756
               return false;
1757
         }
1758

1759
         return true;
1760
      }
1761

1762
   case T_ARRAY_SLICE:
30✔
1763
      {
1764
         if (!is_static(tree_value(expr)))
30✔
1765
            return false;
1766

1767
         assert(tree_ranges(expr) == 1);
30✔
1768

1769
         tree_t r = tree_range(expr, 0);
30✔
1770
         if (!is_static(tree_left(r)) || !is_static(tree_right(r)))
30✔
UNCOV
1771
            return false;
×
1772

1773
         return true;
1774
      }
1775

1776
   case T_ATTR_REF:
9✔
1777
      {
1778
         switch (tree_subkind(expr)) {
9✔
1779
         case ATTR_EVENT:
1780
         case ATTR_ACTIVE:
1781
         case ATTR_LAST_EVENT:
1782
         case ATTR_LAST_ACTIVE:
1783
         case ATTR_LAST_VALUE:
1784
         case ATTR_DRIVING:
1785
         case ATTR_DRIVING_VALUE:
1786
         case ATTR_STABLE:
1787
         case ATTR_QUIET:
1788
            return false;
1789
         case ATTR_POS:
3✔
1790
         case ATTR_VAL:
1791
         case ATTR_LEFTOF:
1792
         case ATTR_RIGHTOF:
1793
         case ATTR_SUCC:
1794
         case ATTR_PRED:
1795
         case ATTR_VALUE:
1796
         case ATTR_IMAGE:
1797
            assert(tree_params(expr) == 1);
3✔
1798
            return is_static(tree_value(tree_param(expr, 0)));
3✔
1799
         case ATTR_LENGTH:
6✔
1800
         case ATTR_LEFT:
1801
         case ATTR_RIGHT:
1802
         case ATTR_LOW:
1803
         case ATTR_HIGH:
1804
            {
1805
               type_t type = tree_type(tree_name(expr));
6✔
1806
               if (type_is_unconstrained(type))
6✔
1807
                  return false;
1808

1809
               int64_t dim = 1;
3✔
1810
               if (tree_params(expr) == 1)
3✔
UNCOV
1811
                  dim = assume_int(tree_value(tree_param(expr, 0)));
×
1812

1813
               tree_t r = range_of(type, dim - 1);
3✔
1814
               if (tree_subkind(r) == RANGE_EXPR)
3✔
1815
                  return false;
1816

1817
               return is_static(tree_left(r)) && is_static(tree_right(r));
3✔
1818
            }
UNCOV
1819
         default:
×
1820
            return true;
×
1821
         }
1822
      }
1823

UNCOV
1824
   default:
×
1825
      return false;
×
1826
   }
1827
}
1828

1829
tree_t longest_static_prefix(tree_t expr)
22,513✔
1830
{
1831
   switch (tree_kind(expr)) {
22,513✔
1832
   case T_ARRAY_REF:
4,027✔
1833
      {
1834
         tree_t value = tree_value(expr);
4,027✔
1835
         tree_t prefix = longest_static_prefix(value);
4,027✔
1836

1837
         if (prefix != value)
4,027✔
1838
            return prefix;
1839

1840
         const int nparams = tree_params(expr);
3,999✔
1841
         for (int i = 0; i < nparams; i++) {
8,182✔
1842
            if (!is_static(tree_value(tree_param(expr, i))))
4,425✔
1843
               return prefix;
1844
         }
1845

1846
         return expr;
1847
      }
1848

1849
   case T_ARRAY_SLICE:
651✔
1850
      {
1851
         tree_t value = tree_value(expr);
651✔
1852
         tree_t prefix = longest_static_prefix(value);
651✔
1853

1854
         if (prefix != value)
651✔
1855
            return prefix;
1856

1857
         assert(tree_ranges(expr) == 1);
644✔
1858

1859
         tree_t r = tree_range(expr, 0);
644✔
1860
         if (tree_subkind(r) == RANGE_EXPR)
644✔
1861
            return prefix;
1862
         else if (!is_static(tree_left(r)) || !is_static(tree_right(r)))
638✔
1863
            return prefix;
16✔
1864

1865
         return expr;
1866
      }
1867

1868
   case T_RECORD_REF:
1,107✔
1869
      {
1870
         tree_t value = tree_value(expr);
1,107✔
1871
         tree_t prefix = longest_static_prefix(value);
1,107✔
1872

1873
         if (prefix != value)
1,107✔
1874
            return prefix;
21✔
1875

1876
         return expr;
1877
      }
1878

1879
   default:
1880
      return expr;
1881
   }
1882
}
1883

1884
tree_t body_of(tree_t pack)
1,653✔
1885
{
1886
   const tree_kind_t kind = tree_kind(pack);
1,653✔
1887
   if (kind == T_PACK_INST)
1,653✔
1888
      return NULL;
1889

1890
   assert(tree_kind(pack) == T_PACKAGE);
1,653✔
1891

1892
   ident_t body_i = well_known(W_BODY);
1,653✔
1893
   ident_t body_name = ident_prefix(tree_ident(pack), body_i, '-');
1,653✔
1894
   return lib_get_qualified(body_name);
1,653✔
1895
}
1896

1897
tree_t find_generic_map(tree_t unit, int pos, tree_t g)
587✔
1898
{
1899
   const int ngenmaps = tree_genmaps(unit);
587✔
1900

1901
   if (pos < ngenmaps) {
587✔
1902
      tree_t m = tree_genmap(unit, pos);
449✔
1903
      if (tree_subkind(m) == P_POS && tree_pos(m) == pos)
449✔
1904
         return tree_value(m);
303✔
1905
   }
1906

1907
   for (int j = 0; j < ngenmaps; j++) {
998✔
1908
      tree_t m = tree_genmap(unit, j);
860✔
1909
      switch (tree_subkind(m)) {
860✔
1910
      case P_NAMED:
440✔
1911
         {
1912
            tree_t name = tree_name(m);
440✔
1913
            assert(tree_kind(name) == T_REF);
440✔
1914

1915
            if (tree_has_ref(name) && tree_ref(name) == g)
440✔
1916
               return tree_value(m);
15✔
1917
         }
1918
         break;
1919

1920
      case P_POS:
420✔
1921
         if (tree_pos(m) == pos)
420✔
1922
            return tree_value(m);
131✔
1923
         break;
1924

1925
      default:
1926
         break;
1927
      }
1928
   }
1929

1930
   return NULL;
1931
}
1932

1933
bool relaxed_rules(void)
542,537✔
1934
{
1935
   return opt_get_int(OPT_RELAXED);
542,537✔
1936
}
1937

1938
bool is_type_attribute(attr_kind_t kind)
69,007✔
1939
{
1940
   switch (kind) {
69,007✔
1941
   case ATTR_SUBTYPE:
1942
   case ATTR_BASE:
1943
   case ATTR_ELEMENT:
1944
   case ATTR_DESIGNATED_SUBTYPE:
1945
   case ATTR_INDEX:
1946
      return true;
1947
   default:
68,360✔
1948
      return false;
68,360✔
1949
   }
1950
}
1951

1952
bool attribute_has_param(attr_kind_t attr)
22,965✔
1953
{
1954
   switch (attr) {
22,965✔
1955
   case ATTR_IMAGE:
1956
   case ATTR_SUCC:
1957
   case ATTR_PRED:
1958
   case ATTR_DELAYED:
1959
   case ATTR_LEFTOF:
1960
   case ATTR_RIGHTOF:
1961
   case ATTR_VALUE:
1962
   case ATTR_POS:
1963
   case ATTR_LOW:
1964
   case ATTR_HIGH:
1965
   case ATTR_LEFT:
1966
   case ATTR_RIGHT:
1967
   case ATTR_LENGTH:
1968
   case ATTR_RANGE:
1969
   case ATTR_REVERSE_RANGE:
1970
   case ATTR_VAL:
1971
   case ATTR_QUIET:
1972
   case ATTR_STABLE:
1973
   case ATTR_INDEX:
1974
   case ATTR_ASCENDING:
1975
      return true;
1976
   default:
2,176✔
1977
      return false;
2,176✔
1978
   }
1979
}
1980

1981
type_t get_type_or_null(tree_t t)
2,151,168✔
1982
{
1983
   switch (tree_kind(t)) {
2,151,168✔
1984
   case T_LIBRARY:
1985
   case T_ATTR_SPEC:
1986
   case T_PACKAGE:
1987
   case T_PACK_INST:
1988
   case T_PACK_BODY:
1989
   case T_ENTITY:
1990
   case T_ARCH:
1991
   case T_PROCESS:
1992
   case T_COMPONENT:
1993
   case T_INSTANCE:
1994
   case T_CONCURRENT:
1995
   case T_BLOCK:
1996
   case T_WHILE:
1997
   case T_FOR:
1998
   case T_LOOP:
1999
   case T_GROUP_TEMPLATE:
2000
   case T_CONFIGURATION:
2001
   case T_GROUP:
2002
   case T_FOR_GENERATE:
2003
   case T_IF_GENERATE:
2004
   case T_CASE_GENERATE:
2005
   case T_USE:
2006
   case T_CONTEXT:
2007
   case T_PSL_DECL:
2008
   case T_PSL_DIRECT:
2009
   case T_WAVEFORM:
2010
      return NULL;
2011
   default:
2,062,683✔
2012
      if (tree_has_type(t))
2,062,683✔
2013
         return tree_type(t);
2,061,315✔
2014
      else
2015
         return NULL;
2016
   }
2017
}
2018

2019
type_t subtype_for_string(tree_t str, type_t base)
25,619✔
2020
{
2021
   if (type_const_bounds(base))
25,619✔
2022
      return base;    // Can be checked statically
2023
   else if (!type_is_unconstrained(base))
22,507✔
2024
      base = type_base_recur(base);
149✔
2025

2026
   // Construct a new constrained array subtype: the direction and
2027
   // bounds are the same as those for a positional array aggregate
2028
   type_t sub = type_new(T_SUBTYPE);
22,507✔
2029
   type_set_base(sub, base);
22,507✔
2030

2031
   type_t index_type = index_type_of(base, 0);
22,507✔
2032
   const bool is_enum = type_is_enum(index_type);
22,507✔
2033

2034
   // The direction is determined by the index type
2035
   range_kind_t dir = direction_of(index_type, 0);
22,507✔
2036
   tree_t index_r = range_of(index_type, 0);
22,507✔
2037

2038
   // The left bound is the left of the index type and the right bound
2039
   // is determined by the number of elements
2040

2041
   tree_t left = NULL, right = NULL;
22,507✔
2042
   const int nchars = tree_chars(str);
22,507✔
2043

2044
   if (is_enum) {
22,507✔
2045
      const int nlits = type_enum_literals(type_base_recur(index_type));
14✔
2046
      int64_t index_left = assume_int(tree_left(index_r));
14✔
2047

2048
      int64_t iright, ileft;
14✔
2049
      if (nchars == 0) {
14✔
2050
         iright = index_left;
1✔
2051
         ileft = assume_int(tree_right(index_r));
1✔
2052
      }
2053
      else if (dir == RANGE_DOWNTO) {
13✔
UNCOV
2054
         ileft = index_left;
×
2055
         iright = MIN(nlits - 1, MAX(0, index_left - nchars + 1));
×
2056
      }
2057
      else {
2058
         ileft = index_left;
13✔
2059
         iright = MIN(nlits - 1, MAX(0, index_left + nchars - 1));
13✔
2060
      }
2061

2062
      left = get_enum_lit(str, index_type, ileft);
14✔
2063
      right = get_enum_lit(str, index_type, iright);
14✔
2064
   }
2065
   else {
2066
      left = tree_left(index_r);
22,493✔
2067

2068
      int64_t iright;
22,493✔
2069
      if (dir == RANGE_DOWNTO)
22,493✔
UNCOV
2070
         iright = assume_int(left) - nchars + 1;
×
2071
      else
2072
         iright = assume_int(left) + nchars - 1;
22,493✔
2073

2074
      right = get_int_lit(str, index_type, iright);
22,493✔
2075
   }
2076

2077
   tree_t r = tree_new(T_RANGE);
22,507✔
2078
   tree_set_subkind(r, dir);
22,507✔
2079
   tree_set_left(r, left);
22,507✔
2080
   tree_set_right(r, right);
22,507✔
2081
   tree_set_loc(r, tree_loc(str));
22,507✔
2082
   tree_set_type(r, index_type);
22,507✔
2083

2084
   tree_t c = tree_new(T_CONSTRAINT);
22,507✔
2085
   tree_set_subkind(c, C_INDEX);
22,507✔
2086
   tree_add_range(c, r);
22,507✔
2087
   tree_set_loc(c, tree_loc(str));
22,507✔
2088

2089
   type_set_constraint(sub, c);
22,507✔
2090

2091
   return sub;
22,507✔
2092
}
2093

2094
tree_t change_ref(tree_t name, tree_t new)
2,130✔
2095
{
2096
   switch (tree_kind(name)) {
2,130✔
2097
   case T_REF:
1,497✔
2098
      return make_ref(new);
1,497✔
2099

2100
   case T_ARRAY_REF:
99✔
2101
      {
2102
         tree_t t = tree_new(T_ARRAY_REF);
99✔
2103
         tree_set_loc(t, tree_loc(name));
99✔
2104
         tree_set_value(t, change_ref(tree_value(name), new));
99✔
2105
         tree_set_type(t, tree_type(name));
99✔
2106

2107
         const int nparams = tree_params(name);
99✔
2108
         for (int i = 0; i < nparams; i++)
198✔
2109
            tree_add_param(t, tree_param(name, i));
99✔
2110

2111
         return t;
2112
      }
2113

2114
   case T_ARRAY_SLICE:
46✔
2115
      {
2116
         tree_t t = tree_new(T_ARRAY_SLICE);
46✔
2117
         tree_set_loc(t, tree_loc(name));
46✔
2118
         tree_set_value(t, change_ref(tree_value(name), new));
46✔
2119
         tree_set_type(t, tree_type(name));
46✔
2120
         tree_add_range(t, tree_range(name, 0));
46✔
2121

2122
         return t;
46✔
2123
      }
2124

2125
   case T_RECORD_REF:
380✔
2126
      {
2127
         tree_t t = tree_new(T_RECORD_REF);
380✔
2128
         tree_set_loc(t, tree_loc(name));
380✔
2129
         tree_set_value(t, change_ref(tree_value(name), new));
380✔
2130
         tree_set_type(t, tree_type(name));
380✔
2131
         tree_set_ident(t, tree_ident(name));
380✔
2132
         tree_set_ref(t, tree_ref(name));
380✔
2133

2134
         return t;
380✔
2135
      }
2136

2137
   case T_CONV_FUNC:
99✔
2138
      {
2139
         tree_t t = tree_new(T_CONV_FUNC);
99✔
2140
         tree_set_loc(t, tree_loc(name));
99✔
2141
         tree_set_value(t, change_ref(tree_value(name), new));
99✔
2142
         tree_set_ident(t, tree_ident(name));
99✔
2143
         tree_set_type(t, tree_type(name));
99✔
2144
         tree_set_ref(t, tree_ref(name));
99✔
2145

2146
         return t;
99✔
2147
      }
2148

2149
   case T_TYPE_CONV:
9✔
2150
      {
2151
         tree_t t = tree_new(T_TYPE_CONV);
9✔
2152
         tree_set_loc(t, tree_loc(name));
9✔
2153
         tree_set_type(t, tree_type(name));
9✔
2154
         tree_set_value(t, change_ref(tree_value(name), new));
9✔
2155

2156
         return t;
9✔
2157
      }
2158

UNCOV
2159
   default:
×
2160
      fatal_trace("cannot handle tree kind %s in elab_change_ref",
2161
                  tree_kind_str(tree_kind(name)));
2162
   }
2163
}
2164

2165
static void build_wait_for_target(tree_t expr, build_wait_fn_t fn, void *ctx)
2,882✔
2166
{
2167
   switch (tree_kind(expr)) {
2,882✔
2168
   case T_ARRAY_SLICE:
77✔
2169
      build_wait(tree_range(expr, 0), fn, ctx);
77✔
2170
      break;
77✔
2171

2172
   case T_ARRAY_REF:
544✔
2173
      {
2174
         const int nparams = tree_params(expr);
544✔
2175
         for (int i = 0; i < nparams; i++)
1,088✔
2176
            build_wait(tree_value(tree_param(expr, i)), fn, ctx);
544✔
2177
      }
2178
      break;
2179

2180
   default:
2181
      break;
2182
   }
2183
}
2,882✔
2184

2185
void build_wait(tree_t expr, build_wait_fn_t fn, void *ctx)
13,357✔
2186
{
2187
   // LRM 08 section 10.2 has rules for building a wait statement from a
2188
   // sensitivity list. LRM 08 section 11.3 extends these rules to
2189
   // all-sensitised processes.
2190

2191
   switch (tree_kind(expr)) {
16,594✔
2192
   case T_REF:
4,217✔
2193
      if (class_of(tree_ref(expr)) == C_SIGNAL)
4,217✔
2194
         (*fn)(expr, ctx);
2,450✔
2195
      break;
2196

2197
   case T_EXTERNAL_NAME:
7✔
2198
      if (tree_class(expr) == C_SIGNAL)
7✔
2199
         (*fn)(expr, ctx);
7✔
2200
      break;
2201

2202
   case T_WAVEFORM:
2,810✔
2203
   case T_QUALIFIED:
2204
   case T_TYPE_CONV:
2205
   case T_INERTIAL:
2206
      if (tree_has_value(expr))
2,810✔
2207
         build_wait(tree_value(expr), fn, ctx);
2,801✔
2208
      break;
2209

2210
   case T_ASSERT:
397✔
2211
      build_wait(tree_value(expr), fn, ctx);
397✔
2212
      // Fall-through
2213
   case T_REPORT:
398✔
2214
      if (tree_has_message(expr))
398✔
2215
         build_wait(tree_message(expr), fn, ctx);
271✔
2216
      break;
2217

2218
   case T_ARRAY_REF:
806✔
2219
   case T_ARRAY_SLICE:
2220
   case T_RECORD_REF:
2221
      {
2222
         tree_t ref = name_to_ref(expr);
806✔
2223
         if (ref != NULL && class_of(ref) == C_SIGNAL
806✔
2224
             && longest_static_prefix(expr) == expr)
510✔
2225
            (*fn)(expr, ctx);
433✔
2226
         else {
2227
            build_wait(tree_value(expr), fn, ctx);
373✔
2228
            build_wait_for_target(expr, fn, ctx);
373✔
2229
         }
2230
      }
2231
      break;
2232

2233
   case T_FCALL:
1,934✔
2234
   case T_PCALL:
2235
   case T_PROT_FCALL:
2236
   case T_PROT_PCALL:
2237
      {
2238
         tree_t decl = tree_ref(expr);
1,934✔
2239
         const int nparams = tree_params(expr);
1,934✔
2240
         for (int i = 0; i < nparams; i++) {
5,272✔
2241
            tree_t p = tree_param(expr, i), port;
3,338✔
2242
            switch (tree_subkind(p)) {
3,338✔
2243
            case P_POS:
3,338✔
2244
               port = tree_port(decl, tree_pos(p));
3,338✔
2245
               break;
3,338✔
UNCOV
2246
            case P_NAMED:
×
UNCOV
2247
               port = tree_ref(name_to_ref(tree_name(p)));
×
UNCOV
2248
               break;
×
UNCOV
2249
            default:
×
2250
               should_not_reach_here();
2251
            }
2252
            assert(tree_kind(port) == T_PARAM_DECL);
3,338✔
2253

2254
            switch (tree_subkind(port)) {
3,338✔
2255
            case PORT_IN:
3,331✔
2256
            case PORT_INOUT:
2257
            case PORT_ARRAY_VIEW:
2258
            case PORT_RECORD_VIEW:
2259
               build_wait(tree_value(p), fn, ctx);
3,331✔
2260
               break;
3,331✔
2261
            default:
2262
               break;
2263
            }
2264
         }
2265
      }
2266
      break;
2267

2268
   case T_AGGREGATE:
345✔
2269
      {
2270
         const int nassocs = tree_assocs(expr);
345✔
2271
         for (int i = 0; i < nassocs; i++) {
1,293✔
2272
            tree_t a = tree_assoc(expr, i);
948✔
2273
            build_wait(tree_value(a), fn, ctx);
948✔
2274

2275
            switch (tree_subkind(a)) {
948✔
2276
            case A_RANGE:
53✔
2277
            case A_SLICE:
2278
               build_wait(tree_range(a, 0), fn, ctx);
53✔
2279
               break;
53✔
2280
            case A_NAMED:
66✔
2281
               build_wait(tree_name(a), fn, ctx);
66✔
2282
               break;
66✔
2283
            }
2284
         }
2285
      }
2286
      break;
2287

2288
   case T_ATTR_REF:
334✔
2289
      {
2290
         const attr_kind_t predef = tree_subkind(expr);
334✔
2291
         if (predef == ATTR_EVENT || predef == ATTR_ACTIVE)
334✔
2292
            build_wait(tree_name(expr), fn, ctx);
151✔
2293

2294
         const int nparams = tree_params(expr);
334✔
2295
         for (int i = 0; i < nparams; i++)
345✔
2296
            build_wait(tree_value(tree_param(expr, i)), fn, ctx);
11✔
2297
      }
2298
      break;
2299

2300
   case T_LITERAL:
2301
   case T_STRING:
2302
   case T_DUMMY_DRIVER:
2303
      break;
2304

2305
   case T_IF:
220✔
2306
      {
2307
         const int nconds = tree_conds(expr);
220✔
2308
         for (int i = 0; i < nconds; i++)
593✔
2309
            build_wait(tree_cond(expr, i), fn, ctx);
373✔
2310
      }
2311
      break;
2312

2313
   case T_COND_STMT:
377✔
2314
      {
2315
         if (tree_has_value(expr))
377✔
2316
            build_wait(tree_value(expr), fn, ctx);
248✔
2317

2318
         const int nstmts = tree_stmts(expr);
377✔
2319
         for (int i = 0; i < nstmts; i++)
756✔
2320
            build_wait(tree_stmt(expr, i), fn, ctx);
379✔
2321
      }
2322
      break;
2323

2324
   case T_PROCESS:
48✔
2325
   case T_SEQUENCE:
2326
   case T_PROC_BODY:
2327
      {
2328
         const int ndecls = tree_decls(expr);
48✔
2329
         for (int i = 0; i < ndecls; i++) {
66✔
2330
            tree_t d = tree_decl(expr, i);
18✔
2331
            if (tree_kind(d) == T_PROC_BODY)
18✔
2332
               build_wait(d, fn, ctx);
2✔
2333
         }
2334

2335
         const int nstmts = tree_stmts(expr);
48✔
2336
         for (int i = 0; i < nstmts; i++)
108✔
2337
            build_wait(tree_stmt(expr, i), fn, ctx);
60✔
2338
      }
2339
      break;
2340

2341
   case T_SIGNAL_ASSIGN:
2,493✔
2342
      {
2343
         build_wait_for_target(tree_target(expr), fn, ctx);
2,493✔
2344

2345
         const int nwaves = tree_waveforms(expr);
2,493✔
2346
         for (int i = 0; i < nwaves; i++)
5,149✔
2347
            build_wait(tree_waveform(expr, i), fn, ctx);
2,656✔
2348
      }
2349
      break;
2350

2351
   case T_VAR_ASSIGN:
13✔
2352
   case T_FORCE:
2353
      build_wait_for_target(tree_target(expr), fn, ctx);
13✔
2354
      build_wait(tree_value(expr), fn, ctx);
13✔
2355
      break;
13✔
2356

2357
   case T_RELEASE:
3✔
2358
      build_wait_for_target(tree_target(expr), fn, ctx);
3✔
2359
      break;
3✔
2360

2361
   case T_CASE:
45✔
2362
   case T_MATCH_CASE:
2363
      {
2364
         build_wait(tree_value(expr), fn, ctx);
45✔
2365

2366
         const int nstmts = tree_stmts(expr);
45✔
2367
         for (int i = 0; i < nstmts; i++) {
276✔
2368
            tree_t alt = tree_stmt(expr, i);
231✔
2369

2370
            const int nstmts = tree_stmts(alt);
231✔
2371
            for (int j = 0; j < nstmts; j++)
462✔
2372
               build_wait(tree_stmt(alt, j), fn, ctx);
231✔
2373
         }
2374
      }
2375
      break;
2376

2377
   case T_FOR:
16✔
2378
      {
2379
         build_wait(tree_range(expr, 0), fn, ctx);
16✔
2380

2381
         const int nstmts = tree_stmts(expr);
16✔
2382
         for (int i = 0; i < nstmts; i++)
35✔
2383
            build_wait(tree_stmt(expr, i), fn, ctx);
19✔
2384
      }
2385
      break;
2386

2387
   case T_WHILE:
1✔
2388
      build_wait(tree_value(expr), fn, ctx);
1✔
2389
      // Fall-through
2390
   case T_LOOP:
4✔
2391
      {
2392
         const int nstmts = tree_stmts(expr);
4✔
2393
         for (int i = 0; i < nstmts; i++)
20✔
2394
            build_wait(tree_stmt(expr, i), fn, ctx);
16✔
2395
      }
2396
      break;
2397

2398
   case T_NEXT:
9✔
2399
   case T_EXIT:
2400
      if (tree_has_value(expr))
9✔
2401
         build_wait(tree_value(expr), fn, ctx);
6✔
2402
      break;
2403

2404
   case T_RANGE:
146✔
2405
      if (tree_subkind(expr) == RANGE_EXPR)
146✔
2406
         build_wait(tree_value(expr), fn, ctx);
11✔
2407
      else {
2408
         build_wait(tree_left(expr), fn, ctx);
135✔
2409
         build_wait(tree_right(expr), fn, ctx);
135✔
2410
      }
2411
      break;
2412

2413
   case T_OPEN:
2414
      break;
2415

UNCOV
2416
   default:
×
2417
      fatal_trace("Cannot handle tree kind %s in wait expression",
2418
                  tree_kind_str(tree_kind(expr)));
2419
   }
2420
}
13,357✔
2421

2422
void print_syntax(const char *fmt, ...)
1,898✔
2423
{
2424
   LOCAL_TEXT_BUF tb = tb_new();
1,898✔
2425
   bool highlighting = false;
1,898✔
2426
   static bool comment = false, last_was_newline = false;
1,898✔
2427
   for (const char *p = fmt; *p != '\0'; p++) {
10,265✔
2428
      if (comment) {
8,367✔
2429
         if (*p == '\n' || *p == '\r') {
3,166✔
2430
            comment = false;
94✔
2431
            last_was_newline = true;
94✔
2432
            tb_printf(tb, "$$\n");
94✔
2433
         }
2434
         else if (*p != '~' && *p != '#') {
3,072✔
2435
            tb_append(tb, *p);
2,912✔
2436
            last_was_newline = false;
2,912✔
2437
         }
2438
         if (p > fmt && *p == '/' && *(p - 1) == '*') {
3,166✔
2439
            tb_printf(tb, "$$");
10✔
2440
            comment = false;
10✔
2441
            last_was_newline = false;
10✔
2442
         }
2443
      }
2444
      else if (*p == '\r') {
5,201✔
2445
         if (!last_was_newline) {
21✔
UNCOV
2446
            tb_append(tb, '\n');
×
UNCOV
2447
            last_was_newline = true;
×
2448
         }
2449
      }
2450
      else if (*p == '#' && *(p + 1) != '#') {
5,180✔
2451
         tb_printf(tb, "$bold$$cyan$");
353✔
2452
         last_was_newline = false;
353✔
2453
         highlighting = true;
353✔
2454
      }
2455
      else if (*p == '~' && *(p + 1) != '~') {
4,827✔
2456
         tb_printf(tb, "$yellow$");
1✔
2457
         last_was_newline = false;
1✔
2458
         highlighting = true;
1✔
2459
      }
2460
      else if ((*p == '-' && *(p + 1) == '-')
4,826✔
2461
               || (*p == '/' && *(p + 1) == '/')
4,736✔
2462
               || (*p == '/' && *(p + 1) == '*')) {
4,732✔
2463
         tb_printf(tb, "$red$%c", *p);
104✔
2464
         last_was_newline = false;
104✔
2465
         comment = true;
104✔
2466
      }
2467
      else if (!isalnum_iso88591(*p) && *p != '_'
4,722✔
2468
               && *p != '%' && highlighting) {
2,396✔
2469
         tb_printf(tb, "$$%c", *p);
307✔
2470
         last_was_newline = false;
307✔
2471
         highlighting = false;
307✔
2472
      }
2473
      else {
2474
         tb_append(tb, *p);
4,415✔
2475
         last_was_newline = (*p == '\n');
4,415✔
2476
      }
2477
   }
2478

2479
   if (highlighting)
1,898✔
2480
      tb_cat(tb, "$$");
47✔
2481

2482
   va_list ap;
1,898✔
2483
   va_start(ap, fmt);
1,898✔
2484

2485
   if (syntax_buf != NULL) {
1,898✔
2486
      char *stripped LOCAL = strip_color(tb_get(tb), ap);
3,796✔
2487
      tb_cat(syntax_buf, stripped);
1,898✔
2488
   }
2489
   else
UNCOV
2490
      color_vprintf(tb_get(tb), ap);
×
2491

2492
   va_end(ap);
1,898✔
2493
}
1,898✔
2494

2495
void capture_syntax(text_buf_t *tb)
9✔
2496
{
2497
   assert(tb == NULL || syntax_buf == NULL);
9✔
2498
   syntax_buf = tb;
9✔
2499
}
9✔
2500

2501
void analyse_file(const char *file, jit_t *jit, unit_registry_t *ur,
3,585✔
2502
                  mir_context_t *mc)
2503
{
2504
   input_from_file(file);
3,585✔
2505

2506
   switch (source_kind()) {
3,585✔
2507
   case SOURCE_VHDL:
3,507✔
2508
      {
2509
         lib_t work = lib_work();
3,507✔
2510
         int base_errors = 0;
3,507✔
2511
         tree_t unit;
3,507✔
2512
         while (base_errors = error_count(), (unit = parse())) {
13,583✔
2513
            if (error_count() == base_errors) {
10,076✔
2514
               lib_put(work, unit);
10,076✔
2515
               unit_registry_purge(ur, tree_ident(unit));
10,076✔
2516

2517
               simplify_local(unit, jit, ur, mc);
10,076✔
2518
               bounds_check(unit);
10,076✔
2519
            }
2520
            else
UNCOV
2521
               lib_put_error(work, unit);
×
2522
         }
2523
      }
2524
      break;
2525

2526
   case SOURCE_VERILOG:
78✔
2527
      {
2528
         LOCAL_TEXT_BUF tb = tb_new();
156✔
2529
         vlog_preprocess(tb, true);
78✔
2530

2531
         input_from_buffer(tb_get(tb), tb_len(tb), SOURCE_VERILOG);
78✔
2532

2533
         lib_t work = lib_work();
78✔
2534
         vlog_node_t module;
78✔
2535
         while ((module = vlog_parse())) {
248✔
2536
            if (error_count() == 0) {
92✔
2537
               vlog_check(module);
92✔
2538

2539
               if (error_count() == 0) {
92✔
2540
                  vlog_simp(module);
92✔
2541
                  lib_put_vlog(work, module);
92✔
2542
               }
2543
            }
2544
         }
2545
      }
2546
      break;
78✔
2547

UNCOV
2548
   case SOURCE_SDF:
×
2549
      {
UNCOV
2550
         sdf_file_t *sdf_file = sdf_parse(file, 0);
×
UNCOV
2551
         progress("analysed SDF file: %s", file);
×
2552

UNCOV
2553
         if (sdf_file != NULL) {
×
UNCOV
2554
            warnf("SDF is not yet supported");
×
UNCOV
2555
            sdf_file_free(sdf_file);
×
2556
         }
2557
      }
2558
      break;
2559
   }
2560
}
3,582✔
2561

2562
bool all_character_literals(type_t type)
1,988✔
2563
{
2564
   assert(type_is_enum(type));
1,988✔
2565

2566
   type_t base = type_base_recur(type);
1,988✔
2567
   const int nlits = type_enum_literals(base);
1,988✔
2568
   for (int i = 0; i < nlits; i++) {
8,056✔
2569
      if (ident_char(tree_ident(type_enum_literal(base, i)), 0) != '\'')
6,940✔
2570
         return false;
2571
   }
2572

2573
   return true;
2574
}
2575

2576
bool is_operator_symbol(ident_t ident)
27,674✔
2577
{
2578
   const int len = ident_len(ident);
27,674✔
2579
   if (len < 3)
27,674✔
2580
      return false;
2581
   else if (ident_char(ident, 0) != '"')
27,424✔
2582
      return false;
2583
   else if (ident_char(ident, len - 1) != '"')
15,966✔
2584
      return false;
2585

2586
   const well_known_t wk = is_well_known(ident);
15,966✔
2587

2588
   if (standard() < STD_08)
15,966✔
2589
      return wk >= W_OP_AND && wk <= W_OP_NOT;
3,349✔
2590
   else
2591
      return wk >= W_OP_AND && wk <= W_OP_MATCH_GREATER_EQUAL;
12,617✔
2592
}
2593

2594
bool same_tree(tree_t a, tree_t b)
7,145✔
2595
{
2596
   const tree_kind_t akind = tree_kind(a);
7,145✔
2597
   if (akind != tree_kind(b))
7,145✔
2598
      return false;
2599

2600
   switch (akind) {
7,023✔
2601
   case T_REF:
3,373✔
2602
      return tree_ref(a) == tree_ref(b);
3,373✔
2603
   case T_ARRAY_REF:
1,063✔
2604
      {
2605
         if (!same_tree(tree_value(a), tree_value(b)))
1,063✔
2606
            return false;
2607

2608
         const int nparams = tree_params(a);
1,041✔
2609
         assert(nparams == tree_params(b));
1,041✔
2610

2611
         for (int i = 0; i < nparams; i++) {
1,920✔
2612
            tree_t pa = tree_value(tree_param(a, i));
1,716✔
2613
            tree_t pb = tree_value(tree_param(b, i));
1,716✔
2614
            if (!same_tree(pa, pb))
1,716✔
2615
               return false;
2616
         }
2617

2618
         return true;
2619
      }
2620
   case T_ARRAY_SLICE:
38✔
2621
      {
2622
         if (!same_tree(tree_value(a), tree_value(b)))
38✔
2623
            return false;
2624

2625
         tree_t ra = tree_range(a, 0);
38✔
2626
         tree_t rb = tree_range(b, 0);
38✔
2627

2628
         const range_kind_t rakind = tree_subkind(ra);
38✔
2629
         if (rakind != tree_subkind(rb) || rakind == RANGE_EXPR)
38✔
2630
            return false;
2631

2632
         return same_tree(tree_left(ra), tree_left(rb))
38✔
2633
            && same_tree(tree_right(ra), tree_right(rb));
38✔
2634
      }
2635

2636
   case T_RECORD_REF:
747✔
2637
      return tree_ident(a) == tree_ident(b)
747✔
2638
         && same_tree(tree_value(a), tree_value(b));
750✔
2639

2640
   case T_LITERAL:
1,802✔
2641
      {
2642
         const literal_kind_t alkind = tree_subkind(a);
1,802✔
2643
         if (alkind != tree_subkind(b) || alkind != L_INT)
1,802✔
2644
            return false;
2645
         else
2646
            return tree_ival(a) == tree_ival(b);
1,763✔
2647
      }
2648
   default:
2649
      return false;
2650
   }
2651
}
2652

2653
void instance_name_to_path(text_buf_t *tb, const char *str)
9,514✔
2654
{
2655
   bool delete = false;
9,514✔
2656
   for (const char *p = str; *p; p++) {
629,405✔
2657
      if (*p == '@' || (*p == '(' && !isdigit_iso88591(*(p + 1))))
619,891✔
2658
         delete = true;
2659
      else if (*p == ')' && delete)
588,321✔
2660
         delete = false;
2661
      else if (*p == ':') {
567,812✔
2662
         delete = false;
36,516✔
2663
         tb_append(tb, ':');
36,516✔
2664
      }
2665
      else if (!delete)
531,296✔
2666
         tb_append(tb, *p);
324,725✔
2667
   }
2668
}
9,514✔
2669

2670
bool calculate_aggregate_bounds(tree_t expr, range_kind_t *kind,
6,990✔
2671
                                int64_t *left, int64_t *right)
2672
{
2673
   // Calculate the direction and bounds of an array aggregate using the
2674
   // rules in LRM 93 7.3.2.2
2675

2676
   type_t type = tree_type(expr);
6,990✔
2677
   type_t index_type = index_type_of(type, 0);
6,990✔
2678
   if (index_type == NULL || type_is_none(index_type))
6,990✔
2679
      return false;
1✔
2680

2681
   tree_t index_r = range_of(index_type, 0), base_r = index_r;
6,989✔
2682

2683
   int64_t low, high;
6,989✔
2684
   if (!folded_bounds(index_r, &low, &high))
6,989✔
2685
      return false;
2686

2687
   int64_t clow = INT64_MAX, chigh = INT64_MIN;  // Actual bounds computed below
6,974✔
2688

2689
   range_kind_t dir;
6,974✔
2690
   if (type_is_unconstrained(type))
6,974✔
2691
      dir = tree_subkind(index_r);
6,728✔
2692
   else {
2693
      base_r = range_of(type, 0);
246✔
2694
      dir = tree_subkind(base_r);
246✔
2695
   }
2696

2697
   const int nassocs = tree_assocs(expr);
6,974✔
2698

2699
   if (standard() >= STD_08) {
6,974✔
2700
      // VHDL-2008 range association determines index direction for
2701
      // unconstrained aggregate when the expression type matches the
2702
      // array type
2703
      for (int i = 0; i < nassocs; i++) {
14,549✔
2704
         tree_t a = tree_assoc(expr, i);
10,416✔
2705
         if (tree_subkind(a) == A_SLICE)
10,416✔
2706
            dir = tree_subkind(tree_range(a, 0));
54✔
2707
      }
2708
   }
2709

2710
   if (dir != RANGE_TO && dir != RANGE_DOWNTO)
6,974✔
2711
      return false;
2712

2713
   int64_t pos = 0;
2714
   for (int i = 0; i < nassocs; i++) {
19,110✔
2715
      tree_t a = tree_assoc(expr, i);
16,946✔
2716
      int64_t ilow = 0, ihigh = 0;
16,946✔
2717
      const assoc_kind_t akind = tree_subkind(a);
16,946✔
2718

2719
      switch (akind) {
16,946✔
2720
      case A_NAMED:
544✔
2721
         {
2722
            tree_t name = tree_name(a);
544✔
2723
            if (folded_int(name, &ilow))
544✔
2724
               ihigh = ilow;
534✔
2725
            else
2726
               return false;
4,773✔
2727
         }
2728
         break;
534✔
2729

2730
      case A_RANGE:
1,184✔
2731
      case A_SLICE:
2732
         {
2733
            tree_t r = tree_range(a, 0);
1,184✔
2734
            const range_kind_t rkind = tree_subkind(r);
1,184✔
2735
            if (rkind == RANGE_TO || rkind == RANGE_DOWNTO) {
1,184✔
2736
               tree_t left = tree_left(r), right = tree_right(r);
842✔
2737

2738
               int64_t ileft, iright;
842✔
2739
               if (folded_int(left, &ileft) && folded_int(right, &iright)) {
842✔
2740
                  ilow = (rkind == RANGE_TO ? ileft : iright);
409✔
2741
                  ihigh = (rkind == RANGE_TO ? iright : ileft);
409✔
2742
               }
2743
               else
2744
                  return false;
433✔
2745
            }
2746
            else
2747
               return false;
2748
         }
2749
         break;
2750

2751
      case A_OTHERS:
2752
         return false;
2753

2754
      case A_POS:
9,640✔
2755
         if (i == 0) {
9,640✔
2756
            int64_t ileft;
1,469✔
2757
            if (folded_int(tree_left(base_r), &ileft))
1,469✔
2758
               ilow = ihigh = ileft;
1,469✔
2759
            else
UNCOV
2760
               return false;
×
2761
         }
2762
         else if (dir == RANGE_TO)
8,171✔
2763
            ilow = ihigh = clow + pos;
8,169✔
2764
         else
2765
            ilow = ihigh = chigh - pos;
2✔
2766
         pos++;
9,640✔
2767
         break;
9,640✔
2768

2769
      case A_CONCAT:
5,576✔
2770
         {
2771
            type_t value_type = tree_type(tree_value(a));
5,576✔
2772

2773
            int64_t length;
5,576✔
2774
            if (type_is_unconstrained(value_type))
5,576✔
2775
               return false;
3,986✔
2776
            else if (folded_length(range_of(value_type, 0), &length)) {
1,883✔
2777
               if (i == 0) {
1,590✔
2778
                  int64_t ileft;
1,382✔
2779
                  if (folded_int(tree_left(base_r), &ileft))
1,382✔
2780
                     ilow = ihigh = ileft;
1,382✔
2781
                  else
UNCOV
2782
                     return false;
×
2783
               }
2784
               else if (dir == RANGE_TO) {
208✔
2785
                  ilow = clow + pos;
190✔
2786
                  ihigh = ilow + length - 1;
190✔
2787
               }
2788
               else {
2789
                  ihigh = chigh - pos;
18✔
2790
                  ilow = ihigh - length + 1;
18✔
2791
               }
2792
               pos += length;
1,590✔
2793
            }
2794
            else
2795
               return false;
2796
         }
2797
         break;
2798
      }
2799

2800
      clow = MIN(clow, ilow);
12,173✔
2801
      chigh = MAX(chigh, ihigh);
12,173✔
2802
   }
2803

2804
   if (clow < low || chigh > high)
2,164✔
2805
      return false;   // Will raise a bounds check error later
2806

2807
   *kind = dir;
2,159✔
2808
   *left = dir == RANGE_TO ? clow : chigh;
2,159✔
2809
   *right = dir == RANGE_TO ? chigh : clow;
2,159✔
2810

2811
   return true;
2,159✔
2812
}
2813

2814
type_t calculate_aggregate_subtype(tree_t expr)
5,696✔
2815
{
2816
   range_kind_t dir;
5,696✔
2817
   int64_t ileft, iright;
5,696✔
2818
   if (!calculate_aggregate_bounds(expr, &dir, &ileft, &iright))
5,696✔
2819
      return NULL;
2820

2821
   type_t type = tree_type(expr);
2,141✔
2822

2823
   const int ndims = dimension_of(type);
2,141✔
2824
   type_t a0_type = NULL;
2,141✔
2825
   if (ndims > 1) {
2,141✔
2826
      a0_type = tree_type(tree_value(tree_assoc(expr, 0)));
66✔
2827
      if (type_is_unconstrained(a0_type))
66✔
2828
         return NULL;
2829

2830
      assert(dimension_of(a0_type) == ndims - 1);
66✔
2831
   }
2832

2833
   type_t index_type = index_type_of(type, 0);
2,141✔
2834

2835
   tree_t left = get_discrete_lit(expr, index_type, ileft);
2,141✔
2836
   tree_t right = get_discrete_lit(expr, index_type, iright);
2,141✔
2837
   assert(left != NULL && right != NULL);
2,141✔
2838

2839
   type_t sub = type_new(T_SUBTYPE);
2,141✔
2840
   type_set_base(sub, type_base_recur(type));
2,141✔
2841

2842
   type_t elem = type_elem(type);
2,141✔
2843
   if (type_is_unconstrained(elem)) {
2,141✔
2844
      tree_t a0 = tree_assoc(expr, 0);
96✔
2845
      switch (tree_subkind(a0)) {
96✔
2846
      case A_CONCAT:
6✔
2847
      case A_SLICE:
2848
         a0_type = type_elem(tree_type(tree_value(a0)));
6✔
2849
         break;
6✔
2850
      default:
90✔
2851
         a0_type = tree_type(tree_value(a0));
90✔
2852
         break;
90✔
2853
      }
2854

2855
      if (!type_is_unconstrained(a0_type))
96✔
2856
         elem = a0_type;
52✔
2857
   }
2858

2859
   type_set_elem(sub, elem);
2,141✔
2860

2861
   tree_t cons = tree_new(T_CONSTRAINT);
2,141✔
2862
   tree_set_subkind(cons, C_INDEX);
2,141✔
2863

2864
   tree_t r = tree_new(T_RANGE);
2,141✔
2865
   tree_set_subkind(r, dir);
2,141✔
2866
   tree_set_type(r, index_type);
2,141✔
2867
   tree_set_left(r, left);
2,141✔
2868
   tree_set_right(r, right);
2,141✔
2869

2870
   tree_add_range(cons, r);
2,141✔
2871

2872
   for (int i = 1; i < ndims; i++)
2,207✔
2873
      tree_add_range(cons, range_of(a0_type, i - 1));
66✔
2874

2875
   type_set_constraint(sub, cons);
2,141✔
2876

2877
   return sub;
2,141✔
2878
}
2879

2880
bool can_be_signal(type_t type)
10,725✔
2881
{
2882
   switch (type_kind(type)) {
21,142✔
2883
   case T_RECORD:
2,453✔
2884
      {
2885
         const int nfields = type_fields(type);
2,453✔
2886
         for (int i = 0; i < nfields; i++) {
10,655✔
2887
            if (!can_be_signal(tree_type(type_field(type, i))))
8,279✔
2888
               return false;
2889
         }
2890

2891
         return true;
2892
      }
2893
   case T_ARRAY:
4,368✔
2894
      return can_be_signal(type_elem(type));
4,368✔
2895
   case T_SUBTYPE:
6,049✔
2896
      return can_be_signal(type_base(type));
6,049✔
2897
   case T_ACCESS:
2898
   case T_FILE:
2899
   case T_PROTECTED:
2900
   case T_INCOMPLETE:
2901
      return false;
2902
   default:
7,697✔
2903
      return true;
7,697✔
2904
   }
2905
}
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2026 Coveralls, Inc