diff options
author | Martin Sebor <msebor@redhat.com> | 2018-12-23 16:00:45 +0000 |
---|---|---|
committer | Jeff Law <law@gcc.gnu.org> | 2018-12-23 09:00:45 -0700 |
commit | b71bbbe2b22460ff9200613784e631496fcfc054 (patch) | |
tree | a1a6d61bb5147081c7b610d4d5bd12d3a48a9814 /gcc/builtins.h | |
parent | e09aa5bd6df9ec0003f230ba29b8b5545c1b533e (diff) | |
download | gcc-b71bbbe2b22460ff9200613784e631496fcfc054.tar.gz |
builtins.h (c_strlen_data): Add new fields and comments.
* builtins.h (c_strlen_data): Add new fields and comments.
* builtins.c (unterminated_array): Change field reference from
"len" to "minlen" in c_strlen_data instance.
* gimple-fold.c (get_range_strlen): Likewise.
* gimple-ssa-sprintf.c (get_string_length): Likewise.
Co-Authored-By: Jeff Law <law@redhat.com>
From-SVN: r267378
Diffstat (limited to 'gcc/builtins.h')
-rw-r--r-- | gcc/builtins.h | 40 |
1 files changed, 39 insertions, 1 deletions
diff --git a/gcc/builtins.h b/gcc/builtins.h index cf4f9b1b264..472a86d9ad0 100644 --- a/gcc/builtins.h +++ b/gcc/builtins.h @@ -57,10 +57,48 @@ extern bool get_pointer_alignment_1 (tree, unsigned int *, unsigned HOST_WIDE_INT *); extern unsigned int get_pointer_alignment (tree); extern unsigned string_length (const void*, unsigned, unsigned); + struct c_strlen_data { + /* [MINLEN, MAXBOUND, MAXLEN] is a range describing the length of + one or more strings of possibly unknown length. For a single + string of known length the range is a constant where + MINLEN == MAXBOUND == MAXLEN holds. + For other strings, MINLEN is the length of the shortest known + string. MAXBOUND is the length of a string that could be stored + in the largest array referenced by the expression. MAXLEN is + the length of the longest sequence of non-zero bytes + in an object referenced by the expression. For such strings, + MINLEN <= MAXBOUND <= MAXLEN holds. For example, given: + struct A { char a[7], b[]; }; + extern struct A *p; + n = strlen (p->a); + the computed range will be [0, 6, ALL_ONES]. + However, for a conditional expression involving a string + of known length and an array of unknown bound such as + n = strlen (i ? p->b : "123"); + the range will be [3, 3, ALL_ONES]. + MINLEN != 0 && MAXLEN == ALL_ONES indicates that MINLEN is + the length of the shortest known string and implies that + the shortest possible string referenced by the expression may + actually be the empty string. This distinction is useful for + diagnostics. get_range_strlen() return value distinguishes + between these two cases. + As the tighter (and more optimistic) bound, MAXBOUND is suitable + for diagnostics but not for optimization. + As the more conservative bound, MAXLEN is intended to be used + for optimization. */ + tree minlen; + tree maxlen; + tree maxbound; + /* When non-null, NONSTR refers to the declaration known to store + an unterminated constant character array, as in: + const char s[] = { 'a', 'b', 'c' }; + It is used to diagnose uses of such arrays in functions such as + strlen() that expect a nul-terminated string as an argument. */ tree decl; - tree len; + /* Non-constant offset from the beginning of a string not accounted + for in the length range. Used to improve diagnostics. */ tree off; }; |